分享

动态内存分配函数解析

 lchjczw 2012-04-06
引言:对于指针,正确的分配动态内存是十分重要的,本文将着重阐述动态内存分配函数malloc,calloc,realloc以及memset的用法。

  i、对于malloc,在终端输入 #:man malloc可以知道函数,原型是Void calloc(size_t size) ,包含在库函数 stdlib.h中,作用是在内存的堆区分配一个大小为size的连续空间,如果分配内存成功,函数返回新分配内存的首地址,否则,返回NULL,注意:鉴于上述这点,一般在写程序需要判断分配内存是否成功,如下程序语句:   
int p;   
p=(int )malloc(sizeof(int));   
if(p!=NULL)   .................................//需要执行的语句   
else   .........................//打印分配内存不成功出错信息   
通常造成内存分配失败的原因如下:   
1、 内存访问越界   
2、 所需连续的内存空间不足   
 
 
        ii.对于函数calloc用法大致与malloc相同,函数原型为:void callo(size_t num,size_t size),作用是在内存中分配连续大小为numsize的空间,这一点在动态数组内存分配有所体现,返回值以及判断返回是否成功与上面相同,下面重点来讨论   
 
malloc与calloc区别:  
 
               1、后者在返回指向内存的指针之前把它初始化为0。

  2、请求内存数量的方式不同。malloc的参数仅仅是需要分配的内存字节数;calloc的参数包括元素的数量和每个元素的字节数。

  为了说明第一点,请看如下程序:程序

  程序在第6行动态为指针p动态分配了内存, 经过gcc编译,运行结果如下:

  由图可以看出红色标记部分,并没有初始化为零,也就是说在这个单元存在随机数,这样程序在运行时可能会出错。

  将上面的程序用calloc来调用,程序如下:

  见上述程序第6行,用calloc来代替malloc分配内存单元,运行结果如下:

  可以看出在用calloc申请内存时将内存都初始化为0了。

  那么有没有用办法用malloc同时又将内存初始化为0呢?答案是有的,用menset可以实现这一功能将第一个程序做相应改动,程序如下:

  在第七行添加了语句menset(p,0,100),这条语句的意思是在内存单元p所指向的100个内存单元都赋值为0,相当与初始化内存。

  此时在运行此程序将不会再出现形如上述红色标记部分的结果。

  iii.对于realloc(),函数原型是void realloc(void ptr,size_t size),改变ptr所指内存区域的大小为size长度,如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL。当内存不再使用时,应使用free()函数将内存块释放。

  有一点需要注意:当分配内存成功之后,应将原本的指针ptr=NULL,否则会形成野指针,可能造成系统崩溃。

  提示:不论是以上那种方式申请内存,在申请内存之后,最终都要用free释放空间,不然会造成内存泄漏。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多