C語言編程中分配內(nèi)存空間的相關(guān)函數(shù)
C語言malloc()函數(shù):動(dòng)態(tài)分配內(nèi)存空間
頭文件:
#include <stdlib.h>
malloc() 函數(shù)用來動(dòng)態(tài)地分配內(nèi)存空間(如果你不了解動(dòng)態(tài)內(nèi)存分配,請(qǐng)查看:C語言動(dòng)態(tài)內(nèi)存分配及變量存儲(chǔ)類別),其原型為:
void* malloc (size_t size);
【參數(shù)說明】size 為需要分配的內(nèi)存空間的大小,以字節(jié)(Byte)計(jì)。
【函數(shù)說明】malloc() 在堆區(qū)分配一塊指定大小的內(nèi)存空間,用來存放數(shù)據(jù)。這塊內(nèi)存空間在函數(shù)執(zhí)行完成后不會(huì)被初始化,它們的值是未知的。如果希望在分配內(nèi)存的同時(shí)進(jìn)行初始化,請(qǐng)使用 calloc() 函數(shù)。
【返回值】分配成功返回指向該內(nèi)存的地址,失敗則返回 NULL。
由于申請(qǐng)內(nèi)存空間時(shí)可能有也可能沒有,所以需要自行判斷是否申請(qǐng)成功,再進(jìn)行后續(xù)操作。
如果 size 的值為 0,那么返回值會(huì)因標(biāo)準(zhǔn)庫實(shí)現(xiàn)的不同而不同,可能是 NULL,也可能不是,但返回的指針不應(yīng)該再次被引用。
注意:函數(shù)的返回值類型是 void *,void 并不是說沒有返回值或者返回空指針,而是返回的指針類型未知。所以在使用 malloc() 時(shí)通常需要進(jìn)行強(qiáng)制類型轉(zhuǎn)換,將 void 指針轉(zhuǎn)換成我們希望的類型,例如:
char *ptr = (char *)malloc(10); // 分配10個(gè)字節(jié)的內(nèi)存空間,用來存放字符
動(dòng)態(tài)內(nèi)存分配舉例:
#include <stdio.h> /* printf, scanf, NULL */ #include <stdlib.h> /* malloc, free, rand, system */ int main () { int i,n; char * buffer; printf ("輸入字符串的長度:"); scanf ("%d", &i); buffer = (char*)malloc(i+1); // 字符串最后包含 \0 if(buffer==NULL) exit(1); // 判斷是否分配成功 // 隨機(jī)生成字符串 for(n=0; n<i; n++) buffer[n] = rand()%26+'a'; buffer[i]='\0'; printf ("隨機(jī)生成的字符串為:%s\n",buffer); free(buffer); // 釋放內(nèi)存空間 system("pause"); return 0; }
運(yùn)行結(jié)果:
輸入字符串的長度:20 隨機(jī)生成的字符串為:phqghumeaylnlfdxfirc
C語言calloc()函數(shù):分配內(nèi)存空間并初始化
頭文件:
#include <stdlib.h>
calloc() 函數(shù)用來動(dòng)態(tài)地分配內(nèi)存空間并初始化為 0,其原型為:
void* calloc (size_t num, size_t size);
calloc() 在內(nèi)存中動(dòng)態(tài)地分配 num 個(gè)長度為 size 的連續(xù)空間,并將每一個(gè)字節(jié)都初始化為 0。所以它的結(jié)果是分配了 num*size 個(gè)字節(jié)長度的內(nèi)存空間,并且每個(gè)字節(jié)的值都是0。
【返回值】分配成功返回指向該內(nèi)存的地址,失敗則返回 NULL。
如果 size 的值為 0,那么返回值會(huì)因標(biāo)準(zhǔn)庫實(shí)現(xiàn)的不同而不同,可能是 NULL,也可能不是,但返回的指針不應(yīng)該再次被引用。
注意:函數(shù)的返回值類型是 void *,void 并不是說沒有返回值或者返回空指針,而是返回的指針類型未知。所以在使用 calloc() 時(shí)通常需要進(jìn)行強(qiáng)制類型轉(zhuǎn)換,將 void 指針轉(zhuǎn)換成我們希望的類型,例如:
char *ptr = (char *)calloc(10, 10); // 分配100個(gè)字節(jié)的內(nèi)存空間
calloc() 與 malloc() 的一個(gè)重要區(qū)別是:calloc() 在動(dòng)態(tài)分配完內(nèi)存后,自動(dòng)初始化該內(nèi)存空間為零,而 malloc() 不初始化,里邊數(shù)據(jù)是未知的垃圾數(shù)據(jù)。下面的兩種寫法是等價(jià)的:
// calloc() 分配內(nèi)存空間并初始化 char *str1 = (char *)calloc(10, 2); // malloc() 分配內(nèi)存空間并用 memset() 初始化 char *str2 = (char *)malloc(20); memset(str2, 0, 20);
代碼示例:
#include <stdio.h> #include <stdlib.h> int main () { int i,n; int * pData; printf ("要輸入的數(shù)字的數(shù)目:"); scanf ("%d",&i); pData = (int*) calloc (i,sizeof(int)); if (pData==NULL) exit (1); for (n=0;n<i;n++) { printf ("請(qǐng)輸入數(shù)字 #%d:",n+1); scanf ("%d",&pData[n]); } printf ("你輸入的數(shù)字為:"); for (n=0;n<i;n++) printf ("%d ",pData[n]); free (pData); system("pause"); return 0; }
運(yùn)行結(jié)果:
要輸入的數(shù)字的數(shù)目:4 請(qǐng)輸入數(shù)字 #1:126 請(qǐng)輸入數(shù)字 #2:343 請(qǐng)輸入數(shù)字 #3:45 請(qǐng)輸入數(shù)字 #4:234 你輸入的數(shù)字為:126 343 45 234
上面的程序會(huì)將你輸入的數(shù)字存儲(chǔ)起來,然后輸出。因?yàn)樵诔绦蜻\(yùn)行時(shí)根據(jù)你的需要來動(dòng)態(tài)分配內(nèi)存,所以每次運(yùn)行程序你可以輸入不同數(shù)目的數(shù)字。
- C語言字符串操作總結(jié)大全(超詳細(xì))
- c語言字符數(shù)組與字符串的使用詳解
- C語言實(shí)現(xiàn)將字符串轉(zhuǎn)換為數(shù)字的方法
- 在C語言中比較兩個(gè)字符串是否相等的方法
- C語言中查找字符在字符串中出現(xiàn)的位置的方法
- C語言切割多層字符串(strtok_r strtok使用方法)
- C語言字符函數(shù)、內(nèi)存函數(shù)功能及實(shí)現(xiàn)代碼
- C語言中字符串的內(nèi)存地址操作的相關(guān)函數(shù)簡(jiǎn)介
- C語言全部內(nèi)存操作函數(shù)的實(shí)現(xiàn)詳細(xì)講解
- C語言進(jìn)階教程之字符串&內(nèi)存函數(shù)
相關(guān)文章
Qt 使用 canon edsdk 實(shí)現(xiàn)實(shí)時(shí)預(yù)覽的示例代碼
這篇文章主要介紹了Qt 使用 canon edsdk 實(shí)現(xiàn)實(shí)時(shí)預(yù)覽的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11C++實(shí)現(xiàn)紅黑樹核心插入實(shí)例代碼
紅黑樹是一種二叉搜索樹,但在每個(gè)結(jié)點(diǎn)上增加一個(gè)存儲(chǔ)位表示結(jié)點(diǎn)的顏色,可以是Red或Black,下面這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)紅黑樹核心插入的相關(guān)資料,需要的朋友可以參考下2023-06-06C++實(shí)現(xiàn)教務(wù)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)教務(wù)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06C語言 while for do while循環(huán)體詳解用法
在不少實(shí)際問題中有許多具有規(guī)律性的重復(fù)操作,因此在程序中就需要重復(fù)執(zhí)行某些語句。一組被重復(fù)執(zhí)行的語句稱之為循環(huán)體,能否繼續(xù)重復(fù),決定循環(huán)的終止條件2021-10-10