跳到内容

C语言中动态内存分配的malloc函数

更新时间
快连VPN:速度和安全性最佳的VPN服务
快连VPN:速度和安全性最佳的VPN服务

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函数的详细内容,更多请关注本站其它相关文章!

更新时间

发表评论

请注意,评论必须在发布之前获得批准。