动态内存分配malloc
来源:互联网 发布:网站中文域名注册 编辑:程序博客网 时间:2024/05/21 17:47
先来段代码:
#include<cstdio>#include<malloc.h>int main(){ int a[5]={4,10,2,8,6}; int len; printf("请输入你要分配的数组的长度:len="); scanf("%d",&len); int * pArr = (int *)malloc(sizeof(int) * len); //sizeof(int)返回的是整形的字节数 //程序请求系统为其分配20字节空间的内存 //malloc函数只能返回第一个字节地址 //强制类型转换告诉编辑器返回的是整形的地址 //所谓整形地址就是说第一个字节的地址+1是跨过了四个字节 /* 这个动态的内存是根据用户的需求来分配的,并且可以动态释放 */ pArr[0] = 4; pArr[1] = 5; pArr[2] = 6; pArr[3] = 6; pArr[4] = 6; for(int i = 0;i<5;i++){ printf("%d ",*(pArr+i)); } free(pArr); //把pArr所代表的动态分配的20个字节的内存释放 printf("释放之后:%d\n",*pArr);return 0;}
malloc()函数只需要一个参数,就是用户需要分配多少内存。并且返回第一个字节的地址。
假如你要自己利用动态内存的方式创建一个int型的数组,那么先想好你要创建多长的。例如上述所示的代码,我要创建长度为5的int型数组。那么就可以表示成:
malloc(sizeof(int)*5);
但这仅仅是创建了20个字节的空间,并没有指定这是int型还是其他类型的,因此我们要指定这是int型的。也就是说第一个字节地址+1,就跨过了4个字节。
因此需要 (int *)malloc(sizeof(int )*5) 这样来进行强制转换。
这样一来:
int * p = (int *)malloc(sizeof(int)*5);
p就指向了20个字节的动态内存的首地址。p+1就指向了下一个,即相当于int a[5]中的a[1]的首地址。
free(首地址) 就可以释放掉内存了
需要注意的是:动态分配内存,必须手动释放掉才可以。否则只能当整个程序彻底终止的时候才能释放。
因此上述代码中,释放掉内存后,*pArr就变成了一个“垃圾数”。
希望大家可以认真仔细的看一下我上面所说的每一句话,非常有助于你理解动态分配内存的知识。
下面在写一个利用动态内存分配的小栗子(其实链表的创建也是用的malloc):
#include<cstdio>#include<malloc.h>struct Student{ int sid; int age;};struct Student * CreateStudent(){ struct Student * p = (struct Student *)malloc(sizeof(struct Student)); p->age = 18; p->sid = 151; return p;};void ShowStudent(struct Student * p){ printf("%d %d\n",p->age,p->sid); }int main(){ struct Student * ps; ps = CreateStudent(); ShowStudent(ps); return 0;}
阅读全文
0 0
- 动态内存分配malloc
- 动态内存分配函数malloc,calloc,realloc
- C_动态内存分配,malloc/free
- 动态内存分配(malloc函数)
- C语言之动态内存分配malloc
- 动态内存分配(malloc colloc realloc free)
- 动态内存分配 malloc,free 函数分析
- malloc free内存分配
- malloc内存分配机制
- malloc内存分配
- malloc内存分配
- c malloc分配内存
- malloc内存分配详解
- c malloc分配内存
- malloc内存分配原理
- malloc分配内存失败
- malloc 内存分配
- 内存分配malloc
- css基础-选择器
- scala 隐式转换(一)
- @Component注解
- cin、cin.clear()、cin.ignore()与输入缓冲区
- python文件读写
- 动态内存分配malloc
- 反射
- JPA实体关系
- java中new一个对象jvm做了哪些事情
- 如何完全的卸载MySQL数据库?
- Flume与Kafka整合案例详解
- windows环境下安装zookeeper
- Java--线程的分类和生命周期
- for循环、php可变变量