C语言动态内存管理malloc、calloc、realloc、free的用法和注意事项

动态内存函数的介绍

1. malloc和free
void * malloc(size_t size);

这个函数向内存申请一块连续可用的空间,并返回指向这块空间的指针。
-如果开辟成功,则返回一个指向开辟好空间的指针。
-如果开辟失败,则返回一个NULL指针,因此malloc的返回值一定要做检查。
-返回值的类型是void*,所以malloc函数并不知道开辟空间的类型,具体在使用的时候使用者自己来决定。
-如果参数size为0,malloc的行为是标准未定义的,取决于编译器。

void * free(void* ptr)
int main()
{
    int *number;  
    number = (int *)malloc(sizeof(int));//分配一个大小为sizeof(int)的存储空间,  
    if(NULL == number)//判断调用是否成功,不成功就退出  
     {  
         return 1;  
     }  
    *number = 100;//初始化  
    free(number);//释放内存  
    number = NULL;//防止出现野指针  
    return 0;
}

2.calloc
void * calloc(size_t num,size_t size)

函数的功能是为num个大小为size的元素开辟一块空间,并且把空间的每个字节初始化为0.

与malloc的区别只在于calloc会在返回地址之前把申请的空间的每个字节初始化为全0.



int main()
{ 
   int *num=(int *)calloc(10,sizeof(int));
   if(NULL==num) 
  { 
    return 1;
   } 
   free(num); 
   num=NULL;
   return 0;
}

3.realloc
void * realloc(void * ptr,size_t size)
-ptr是要调整的内存地址
-size 调整之后的新大小
-返回值为调整之后的内存起始位置
-这个函数调整原内存空间的大小的基础上,还会将原来内存中的数据移动到新空间。

realloc在调整内存空间存在两种情况:

情况1:原有空间之后有足够大的空间,要扩展就原有内存之后直接追加空间,原来空间的数据不发生变化。
情况2:原有空间之后没有足够大的空间,扩展方法:在堆空间上另找一个合适大小的连续空间来使用。这样函数返回的是一个新的内存地址。
int * number;  
int * renumber;  
number = (int *)calloc(5,sizeof(int))  
if(NULL == number)//判断调用是否成功,不成功就退出  
{  
    return 1;  
}  
  
renumber = (int *)realloc(number,3*sizeof(int));  
if(NULL != renumber)//如果分配成功,就让number指向新分配的内存,这样不会造成内存泄漏,  
{ //因为number原来指向的内存已经被自动回收。  
    number = renumber;  
}  
renumber = NULL;  
...  
free(number);//这里只需要free number就可以了。  
number = NULL;  

猜你喜欢

转载自blog.csdn.net/qq_41268108/article/details/80547417