动态内存分配函数解析

动态内存分配函数解析对于指针,正确的分配动态内存是十分重要的,本文将着重阐述动态内存分配函数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),作用是在内存中分配连续大小为num*size的空间,这一点在动态数组内存分配有所体现,返回值以及判断返回是否成功与上面相同,下面重点来讨论malloc与calloc区别:1、后者在返回指向内存的指针之前把它初始化为0

2、请求内存数量的方式不同

malloc的参数仅仅是需要分配的内存字节数;calloc的参数包括元素的数量和每个元素的字节数

iii.对于realloc(),函数原型是*void realloc(void *ptr,size_t size),改变ptr所指内存区域的大小为size长度,如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL

当内存不再使用时,应使用free()函数将内存块释放

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

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

以上内容由大学时代综合整理自互联网,实际情况请以官方资料为准。

相关