C語言動態(tài)數組詳解
更新時間:2021年09月12日 16:27:43 作者:江鋒漁火
本文給大家分享的是一則使用C語言實現動態(tài)數組的代碼,完美解決內存溢出以及內存回收問題,有需要的小伙伴可以參考下
內存分配函數malloc calloc realloc free
| 堆內存分配函數 | 說明 |
|---|---|
| void * malloc(int n) | 形參n為要求分配的字節(jié)數。需要注意的是,malloc函數分配得到的內存空間是未初始化的。必須使用memset函數來初始化。 |
| calloc(10, sizeof(char)); | 兩個參數:單元數,單元的size。分配內存,并清理內存。初始內容全部為0; |
| realloc(p,10); | 調整內存的大??; 分配的內存空間并未初始化;使用新返回的地址, |
| free(void * p) | 釋放指針p所指向的堆上的空間; |
malloc() 不對分配的內存空間做初始化,內存上原有的值不會被清理。
realloc(),在原有內存基礎之上,在堆中間增加連續(xù)的內存,如果原有內存沒有連續(xù)空間可擴展,則新分配一個空間,將原有內存copy到新空間,然后釋放原有內存。
p = malloc(10); //直接申請4k的空間。內存頁大小。 返回值是無類型指針void *,可以強制轉換。 free(p); char *p = calloc(10, sizeof(char)); //兩個參數:單元數,單元的size。 分配內存,并清理內存 char *p2 = realloc(p,10); // 在原有內存基礎之上,在堆中間增加連續(xù)的內存,如果原有內存沒有連續(xù)空間可擴展,則新分配一個空間,將原有內存copy到新空間,然后釋放原有內存。 char *p2 = realloc(NULL,20); //此時,和malloc等價
realloc和malloc一樣,只分配內存,不清理,需要手動初始化。
// 復雜數據內存放在堆里面
內存操作函數 memset memcpy memmove
memset(buf,0,sizeof(buf));//三個參數分別是:要設置的內存地址,要設置的值,值占的內存的字節(jié)數。 將一塊內存初始化為0最長見的方法。 extern void *memset(void *buffer, int c, int count) memcpy(void *dest,void *src,unsigned int count);//將buf1的地址的內存內容全部拷貝到buf2,拷貝大小為第三個參數:字節(jié)一定確保內存區(qū)域沒有內存區(qū)域重疊。 memmove(buf2, buf1, sizeof(buf1));//內存移動,并沒有改變原始內存的值。
二維動態(tài)數組的建立和釋放
在創(chuàng)建動態(tài)數組的過程中我們要遵循一個原則,那就是在創(chuàng)建的時候從外層往里層,逐層創(chuàng)建;
而釋放的時候從里層往外層,逐層釋放。
int main()
{
int num1,num2;
num1 = 4;
num2 = 5;
int **array = (int **)calloc(num1,sizeof(int *));//開辟空間,num1個一維int*型指針
for(int i=0;i<num1;i++)
{
array[i] = (int *)calloc(num2,sizeof(int)); //給每個int *型指針分配內存
}
for(int i=0;i<num1;i++)
{
for(int j=0;j<num2;j++)
{
array[i][j] =i*num2+j+1;
printf("%d\t",array[i][j]);
}
printf("\n");
}
for(int i=0;i<num1;i++)
{
free(array[i]); // 釋放第二維的內存
}
free(array); // 釋放第一維的內存
return 0;
}
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

