新聞中心

        EEPW首頁 > 嵌入式系統 > 牛人業話 > C語言的那些小秘密之內存分配

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

        作者: 時間:2015-03-03 來源:網絡 收藏

          realloc()函數

        本文引用地址:http://www.104case.com/article/270350.htm

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

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

          頭文件:#include 有些編譯器需要#include ,在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是一個函數

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

          跟malloc的區別:

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

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

          頭文件:stdlib.h或malloc.h

          #include

          #include

          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("%dt", p[i]);

          }

          for (i = 0; i < num; i++)

          {

          printf("%dt", p1[i]);

          }

          printf("內存地址: %pn~~~~~~~~n", p);

          for (i = 0; i < num; i++)

          p[i] = i+1;

          for (i = 0; i < num; i++)

          printf("%dt", p[i]);

          printf("n------------------n");

          num = 4;

          p = (long *)realloc(p, num*sizeof(long));

          printf("內存地址: %pn~~~~~~~~n", p);

          for (i = 0; i < num; i++)

          printf("%dt", p[i]);

          printf("n------------------n");

          num = 10;

          p = (long *)realloc(p, num*sizeof(long));

          printf("內存地址: %pn~~~~~~~~n", p);

          for (i = 0; i < num; i++)

          printf("%dt", p[i]);

          free(p);

          free(p1);

          getchar();

          return 0;

          }

          運行結果為:

          

         

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

        c語言相關文章:c語言教程


        c++相關文章:c++教程




        關鍵詞: C語言 內存分配

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 吉安县| 安吉县| 阿荣旗| 五寨县| 特克斯县| 额济纳旗| 柞水县| 修武县| 石河子市| 九江县| 翁牛特旗| 隆回县| 松江区| 垦利县| 赫章县| 皋兰县| 门源| 抚远县| 垫江县| 巩留县| 富平县| 龙里县| 文山县| 革吉县| 常宁市| 信丰县| 昌吉市| 台南市| 仁化县| 南漳县| 澳门| 深泽县| 鄱阳县| 卓资县| 隆化县| 措美县| 桐庐县| 许昌市| 洛隆县| 屯留县| 全椒县|