<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

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

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

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

            realloc()函數(shù)

          本文引用地址:http://www.ex-cimer.com/article/270350.htm

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

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

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

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

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

            注意:這里原始內(nèi)存中的數(shù)據(jù)還是保持不變的。當內(nèi)存不再使用時,應(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。

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

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

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

            calloc()函數(shù)

            calloc是一個函數(shù)

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

            跟malloc的區(qū)別:

            calloc在動態(tài)分配完內(nèi)存后,自動初始化該內(nèi)存空間為零,而malloc不初始化,里邊數(shù)據(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;

            }

            運行結(jié)果為:

            

           

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

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


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




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

          評論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();