C語言的那些小祕密之內存分配

文章轉載:http://blog.csdn.net/bigloomy/article/details/6581706


realloc()函數

原型:extern void *realloc(void *mem_address, unsigned int newsize);

語法:指針名=(數據類型*)realloc(要改變內存大小的指針名,新的大小)。

頭文件:#include <stdlib.h> 有些編譯器需要#include <alloc.h>,在TC2.0中可以使用alloc.h頭文件

功能:先按照newsize指定的大小分配空間,將原有數據從頭到尾拷貝到新分配的內存區域,而後釋放原來mem_address所指內存區域,同時返回新分配的內存區域的首地址。即重新分配存儲器塊的地址。

返回值:如果重新分配成功則返回指向被分配內存的指針,否則返回空指針NULL。

注意:這裏原始內存中的數據還是保持不變的。當內存不再使用時,應使用free()函數將內存塊釋放。

malloc()函數

原型:extern void *malloc(unsigned int num_bytes);

頭文件:在TC2.0中可以用malloc.h或 alloc.h (注意:alloc.h 與 malloc.h 的內容是完全一致的),而在Visual C++6.0中可以用malloc.h或者stdlib.h

功能:分配長度爲num_bytes字節的內存塊

返回值:如果分配成功則返回指向被分配內存的指針,否則返回空指針NULL。當內存不再使用時,應使用free()函數將內存塊釋放。

說明:關於該函數的原型,在舊的版本中malloc返回的是char型指針,新的ANSIC標準規定,該函數返回爲void型指針,因此必要時要進行類型轉換。

calloc()函數

calloc是一個C語言函數

功 能: 在內存的動態存儲區中分配n個長度爲size的連續空間,函數返回一個指向分配起始地址的指針;如果分配不成功,返回NULL。

跟malloc的區別:

calloc在動態分配完內存後,自動初始化該內存空間爲零,而malloc不初始化,裏邊數據是隨機的垃圾數據。

用 法: void *calloc(unsigned n,unsigned size);

頭文件:stdlib.h或malloc.h

#include <stdio.h>
#include <stdlib.h>
int main(void)
{    
 int num = 10;
    int i;    
 long *p = (long *)malloc(num * sizeof(long)); 
 long *p1=(long *)calloc(num,sizeof(long));

 for (i = 0; i < num; i++)
 {
  printf("%d\t", p[i]);
 }
 for (i = 0; i < num; i++)
 {
  printf("%d\t", p1[i]);
 }

 printf("內存地址: %p\n~~~~~~~~\n", p);  
 for (i = 0; i < num; i++)
  p[i] = i+1;   
 for (i = 0; i < num; i++) 
  printf("%d\t", p[i]); 

 printf("\n------------------\n");
    num = 4;    
 p = (long *)realloc(p, num*sizeof(long));  
 printf("內存地址: %p\n~~~~~~~~\n", p);
 for (i = 0; i < num; i++) 
  printf("%d\t", p[i]); 

 printf("\n------------------\n");    
 num = 10;    
 p = (long *)realloc(p, num*sizeof(long));  
 printf("內存地址: %p\n~~~~~~~~\n", p);  
 for (i = 0; i < num; i++) 
  printf("%d\t", p[i]);

 free(p);   
 free(p1);
 getchar();   
 return 0;
}

運行結果爲:

 

由數據可以很直觀的看出他們之間的區別


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章