一步一步学Linux C:浅谈动态内存

使用动态内存时需要用户自己去申请资源和释放资源。用户可以随时的分配所需空间,根据需要分配空间大小,并在最后释放申请内存。

动态内存也存在隐患:在大型的项目当中管理申请的动态内存是很复杂的,以及释放申请的内存有难想起的。在释放动态内存时可能不止一个指针指向了该内存,所以释放的时候是很容易出错的。内存无法释放就会造成内存泄露,这也就是为什么服务器要经常的每个一段时间重启的原因。

内存管理操作:

分配内存函数:

  1. #include <stdlib.h>  
  2. void *malloc(size_t size)   
  3. void *calloc(size_t nmemb,size_tsize)  

函数malloc中size是分配内存的大小,以字节为单位。

函数calloc中size是数据项的大小,nmemb是数据项的个数。所以分配内存大小为size*nmemb

malloc和calloc的最大区别是calloc会把申请到的内出初始化为0

调用成功都会返回分配内存的指针,调用失败都返回NULL

内存的调整:

对于realloc(),函数原型是void* realloc(void *ptr,size_t  size),改变ptr所指内存区域的大小为size长度,size可以大于或小于原动态内存的大小,realloc通常是在原数据的基础上调整动态内存的大小是,原数据内容不变。当size大于原来的数据,且在原来位置无法调整时,realloc会重新开辟内存,把原来的数据复制到这来。如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL。当内存不再使用时,应使用free()函数将内存块释放。有一点需要注意:当分配内存成功之后,应将原本的指针ptr=NULL,否则会形成野指针,可能造成系统崩溃。不论是以上那种方式申请内存,在申请内存之后,最终都要用free释放空间,不然会造成内存泄漏。

如果ptr为NULL时realloc相当于malloc,如果size=0时相当于free

内存的释放:

  1. #include<stdlib.h>   
  2. voidfree(void *pr);  

free用于释放有malloc或calloc申请的动态内存。内存释放后再去使用指针会发生错误。

实例如下:

  1. #include <stdio.h>   
  2.   
  3. #include <stdlib.h>   
  4.   
  5.    
  6.   
  7. char *alloc_test();  
  8.   
  9.    
  10.   
  11. main()  
  12.   
  13. {  
  14.   
  15.      char*p1,*p2;  
  16.   
  17.      p1= alloc_test();  
  18.   
  19.      p2= p1;  
  20.   
  21.      printf("%s\n",p1);  
  22.   
  23.      printf("%s\n",p2);  
  24.   
  25.      free(p1);  
  26.   
  27.      //free(p2);   
  28.   
  29. }  
  30.   
  31. char *alloc_test()  
  32.   
  33. {  
  34.   
  35.      char*pchar = malloc(20);  
  36.   
  37.      strcpy(pchar,"helloalloc_test");  
  38.   
  39.      returnpchar;  
  40.   
  41. }  

要把free(p2);注释掉

否则会出错,以为p1,p2同时指向了一个内存,通过p1释放了内存块,当通过p2再次释放内存当然就出错了。

pchar也指向了内存块,但是又过p1释放的内存,因为调用完alloc_test后pchar配释放了当内存块并没有被释放。

相关推荐