您好,登錄后才能下訂單哦!
malloc和calloc可以動態(tài)的分配內(nèi)存,即:編譯的時候不會分配內(nèi)存運(yùn)行的時候才會分配內(nèi)存。很像高級語言中的new關(guān)鍵字。
這樣的好處自然是不用多說?,F(xiàn)在對他們的用法及注意點(diǎn)進(jìn)行總結(jié):
先看malloc,代碼如下:
#include <stdio.h> #include <stdlib.h> #define N 5 int main() { int i = 0; int * nums; nums = (int *)malloc(N*sizeof(int)); //其實(shí)nums相當(dāng)與[]數(shù)組:一個int類型的數(shù)組 //為nums賦值 for(i=0 ; i < N ; i++) { printf("請輸入第%d個數(shù)值:" , i +1); scanf("%d",(nums+i)); } for(i = 0 ; i < N ; i++) { printf("第%d個元素的值為 : %d\n" , i + 1 , *(nums + i)); } free(nums); nums = NULL; return 0; }
運(yùn)行結(jié)果如下圖:
現(xiàn)對malloc的解釋如下:
1,malloc定義一個數(shù)組,數(shù)組類型需要使用強(qiáng)轉(zhuǎn)指針,比如(int *)的意思就是:定義了一個int類型的數(shù)組,至于數(shù)組的長度即時在N*sizeof(int)中表現(xiàn)。N*sizeof(int)即為 5X4=20,既是在內(nèi)存中動態(tài)的分配20個字節(jié),而每個int類型占4個字節(jié)(sizeof(int)獲得的 , 可能在其他的IDE中是不一樣的)。其實(shí)用20/4就可以得到數(shù)組的長度為5了。
2,用完后需要手動free掉指針,這比單純的使用數(shù)組的效率要高,但是存在一定的風(fēng)險。
再看 calloc,代碼如下:
#include <stdio.h> #include <stdlib.h> #define N 5 int main() { int i = 0; int * nums = NULL; nums = calloc(N,sizeof(int)); //為nums賦值 for(i=0 ; i < N ; i++) { printf("請輸入第%d個數(shù)值:" , i +1); scanf("%d",(nums+i)); } for(i = 0 ; i < N ; i++) { printf("第%d個元素的值為 : %d\n" , i + 1 , *(nums + i)); } free(nums); nums = NULL; return 0; }
運(yùn)行的結(jié)果和malloc的一樣,就不再給圖了。
事實(shí)上,calloc和malloc產(chǎn)生的想過是一樣的,但是它們的用法上有些區(qū)別:
1,malloc需要強(qiáng)制轉(zhuǎn)換,而calloc不需要強(qiáng)制轉(zhuǎn)換
2,malloc和calloc的參數(shù)是不一樣的:
①,malloc只有一個參數(shù), 為數(shù)組的大小*數(shù)組類型所占的空間字節(jié)大小,為一個參數(shù)
②,calloc有2個參數(shù), 1 : 數(shù)組的大小 ; 2 : 數(shù)組類型所占的空間字節(jié)大小。
現(xiàn)在提出一個注意點(diǎn):
關(guān)于 free(nums) : 釋放nums一定要注意,如果使用了nums++等讓指針美譽(yù)指向數(shù)組的頭(第一個元素),那么即使是使用了free,指針也不能被釋放掉。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。