C语言中的malloc函数
需要包含头文件:
#i nclude
立即学习“C语言免费学习笔记(深入)”;
或
#i nclude
立即学习“C语言免费学习笔记(深入)”;
函数声明(函数原型):
void *malloc(int size);
malloc函数用于向系统申请分配指定大小的内存空间,返回类型为void*。在C和C++中,void*类型的指针可以强制转换为任何其他类型的指针。
从函数声明上可以看出,malloc 和 new 至少有两个不同之处:new 返回指定类型的指针,并且可以自动计算所需的大小。例如:
int *p;
p = new int; //返回类型为int* 类型(整数型指针),分配大小为 sizeof(int);
或:
int* parr;
parr = new int [100]; //返回类型为 int* 类型(整数型指针),分配大小为 sizeof(int) * 100;
而 malloc 则必须由我们计算要字节数,并且在返回后强行转换为实际类型的指针。
int* p;
p = (int *) malloc (sizeof(int));
第一、malloc 函数返回的是 void * 类型,如果你写成:p = malloc (sizeof(int)); 则程序无法通过编译,报错:“不能将 void* 赋值给 int * 类型变量”。所以必须通过 (int *) 来将强制转换。
第二、函数的实参为 sizeof(int) ,用于指明一个整型数据需要的大小。如果你写成:
int* p = (int *) malloc (1);
代码也能通过编译,但事实上只分配了1个字节大小的内存空间,当你往里头存入一个整数,就会有3个字节无家可归,而直接“住进邻居家”!造成的结果是后面的内存中原有数据内容全部被清空。
malloc 也可以达到 new [] 的效果,申请出一段连续的内存,方法无非是指定你所需要内存大小。
比如想分配100个int类型的空间:
int* p = (int *) malloc ( sizeof(int) * 100 ); //分配可以放得下100个整数的内存空间。
另外有一点不能直接看出的区别是,malloc 只管分配内存,并不能对所得的内存进行初始化,所以得到的一片新内存中,其值将是随机的。
除了分配及最后释放的方法不一样以外,通过malloc或new得到指针,在其它操作上保持一致。
C语言malloc函数的问题我在下面函数两次用malloc给 p共6个单位内存
展开全部
你分两次分配内存,前一次3个int,可惜你把它丢失了,第二次分配了三个还用这个指针,你没给新内存头三个int赋值,直接越界写了界外的3个int单元,程序没有立即崩溃已经是很侥幸了
int *p, *p1,i;
p = (int *)malloc(3*sizeof(int));
for(i=0;i
printf(" int put:");
scanf("%d",p+i);
}
p1 = (int *)malloc(3*sizeof(int));
for(i=0; i
printf(" int put:");
scanf("%d",p1+i);
}
for(i=0;i
for(i=0;i
超简单的malloc函数问题
这个可以看一下malloc函数的原型
void* malloc(int)
malloc的参数是一个整形,表示要申请的内存数,以字节为单位,返回值是指向那段内存的一个指针,是空类型的指针。
而sizeof是一个运算符,通过他能得到一个类型或者变量的占内存的字节数,结果为整形。所以pp=(float *)malloc(sizeof(float));实际上先计算sizeof(float),得到一个float型占内存的字节数,32位环境下应该是4字节,结果就为4,然后malloc(4)申请了一个4字节的内存空间,并返回这块内存区域的地址,然后强制转化为float*类型。
关于链表是每一个链表的元素保存了下一个或上一个元素的地址,自然每一个链表元素都要占内存空间的,当要新加入一个链表的元素时首先要为这个元素分配地址,不然数据没有地方保存。
以上就是C语言中动态内存分配的malloc函数的详细内容,更多请关注本站其它相关文章!