C语言动态内存分配函数解析

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

  一、对于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、 所需连续的内存空间不足

  二、对于函数calloc用法大致与malloc相同,函数原型为:

  void *callo(size_t  num,size_t  size),作用是在内存中分配连续大小为num*size的空间,这一点在动态数组内存分配有所体现,返回值以及判断返回是否成功与上面相同,下面重点来讨论malloc与calloc区别:

  1、后者在返回指向内存的指针之前把它初始化为0。

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

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

C语言动态内存分配函数解析_第1张图片


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

C语言动态内存分配函数解析_第2张图片


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

C语言动态内存分配函数解析_第3张图片


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

C语言动态内存分配函数解析_第4张图片


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



  在第七行添加了语句menset(p,0,100),这条语句的意思是在内存单元p所指向的100个内存单元都赋值为0,相当与初始化内存。此时在运行此程序将不会再出现形如上述红色标记部分的结果。

  三、对于realloc(),函数原型是*void realloc(void  *ptr,size_t  size),改变ptr所指内存区域的大小为size长度,如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL。当内存不再使用时,应使用free()函数将内存块释放。有一点需要注意:当分配内存成功之后,应将原本的指针ptr=NULL,否则会形成野指针,可能造成系统崩溃。

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

你可能感兴趣的:(C语言,malloc,realloc,calloc,动态内存分配)