• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁(yè) > 嵌入式系統(tǒng) > 牛人業(yè)話 > C語(yǔ)言的那些小秘密之內(nèi)存分配

    C語(yǔ)言的那些小秘密之內(nèi)存分配

    作者: 時(shí)間:2015-03-03 來(lái)源:網(wǎng)絡(luò) 收藏

      realloc()函數(shù)

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

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

      語(yǔ)法:指針名=(數(shù)據(jù)類型*)realloc(要改變內(nèi)存大小的指針名,新的大小)。

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

      功能:先按照newsize指定的大小分配空間,將原有數(shù)據(jù)從頭到尾拷貝到新分配的內(nèi)存區(qū)域,而后釋放原來(lái)mem_address所指內(nèi)存區(qū)域,同時(shí)返回新分配的內(nèi)存區(qū)域的首地址。即重新分配存儲(chǔ)器塊的地址。

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

      注意:這里原始內(nèi)存中的數(shù)據(jù)還是保持不變的。當(dāng)內(nèi)存不再使用時(shí),應(yīng)使用free()函數(shù)將內(nèi)存塊釋放。

      malloc()函數(shù)

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

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

      功能:分配長(zhǎng)度為num_bytes字節(jié)的內(nèi)存塊

      返回值:如果分配成功則返回指向被分配內(nèi)存的指針,否則返回空指針NULL。當(dāng)內(nèi)存不再使用時(shí),應(yīng)使用free()函數(shù)將內(nèi)存塊釋放。

      說(shuō)明:關(guān)于該函數(shù)的原型,在舊的版本中malloc返回的是char型指針,新的ANSIC標(biāo)準(zhǔn)規(guī)定,該函數(shù)返回為void型指針,因此必要時(shí)要進(jìn)行類型轉(zhuǎn)換。

      calloc()函數(shù)

      calloc是一個(gè)函數(shù)

      功 能: 在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū)中分配n個(gè)長(zhǎng)度為size的連續(xù)空間,函數(shù)返回一個(gè)指向分配起始地址的指針;如果分配不成功,返回NULL。

      跟malloc的區(qū)別:

      calloc在動(dòng)態(tài)分配完內(nèi)存后,自動(dòng)初始化該內(nèi)存空間為零,而malloc不初始化,里邊數(shù)據(jù)是隨機(jī)的垃圾數(shù)據(jù)。

      用 法: 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("內(nèi)存地址: %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("內(nèi)存地址: %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("內(nèi)存地址: %pn~~~~~~~~n", p);

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

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

      free(p);

      free(p1);

      getchar();

      return 0;

      }

      運(yùn)行結(jié)果為:

      

     

      由數(shù)據(jù)可以很直觀的看出他們之間的區(qū)別

    c語(yǔ)言相關(guān)文章:c語(yǔ)言教程


    c++相關(guān)文章:c++教程




    關(guān)鍵詞: C語(yǔ)言 內(nèi)存分配

    評(píng)論


    相關(guān)推薦

    技術(shù)專區(qū)

    關(guān)閉
    主站蜘蛛池模板: 扎鲁特旗| 寿光市| 胶南市| 正蓝旗| 阜平县| 济源市| 聂拉木县| 林芝县| 泰州市| 新建县| 册亨县| 仁寿县| 磐安县| 乌审旗| 盱眙县| 岳普湖县| 吉木乃县| 迭部县| 大足县| 聂荣县| 新民市| 静宁县| 澄迈县| 东安县| 泾源县| 静乐县| 和龙市| 松潘县| 济宁市| 佳木斯市| 额尔古纳市| 桓台县| 怀化市| 家居| 和田县| 凤阳县| 绥阳县| 城口县| 新闻| 蒙自县| 城固县|