C語言動態數組詳解
內存分配函數malloc calloc realloc free
堆內存分配函數 | 說明 |
---|---|
void * malloc(int n) | 形參n為要求分配的字節數。需要註意的是,malloc函數分配得到的內存空間是未初始化的。必須使用memset函數來初始化。 |
calloc(10, sizeof(char)); | 兩個參數:單元數,單元的size。分配內存,並清理內存。初始內容全部為0; |
realloc(p,10); | 調整內存的大小; 分配的內存空間並未初始化;使用新返回的地址, |
free(void * p) | 釋放指針p所指向的堆上的空間; |
malloc() 不對分配的內存空間做初始化,內存上原有的值不會被清理。
realloc(),在原有內存基礎之上,在堆中間增加連續的內存,如果原有內存沒有連續空間可擴展,則新分配一個空間,將原有內存copy到新空間,然後釋放原有內存。
p = malloc(10); //直接申請4k的空間。內存頁大小。 返回值是無類型指針void *,可以強制轉換。 free(p); char *p = calloc(10, sizeof(char)); //兩個參數:單元數,單元的size。 分配內存,並清理內存 char *p2 = realloc(p,10); // 在原有內存基礎之上,在堆中間增加連續的內存,如果原有內存沒有連續空間可擴展,則新分配一個空間,將原有內存copy到新空間,然後釋放原有內存。 char *p2 = realloc(NULL,20); //此時,和malloc等價
realloc和malloc一樣,隻分配內存,不清理,需要手動初始化。
// 復雜數據內存放在堆裡面
內存操作函數 memset memcpy memmove
memset(buf,0,sizeof(buf));//三個參數分別是:要設置的內存地址,要設置的值,值占的內存的字節數。 將一塊內存初始化為0最長見的方法。 extern void *memset(void *buffer, int c, int count) memcpy(void *dest,void *src,unsigned int count);//將buf1的地址的內存內容全部拷貝到buf2,拷貝大小為第三個參數:字節一定確保內存區域沒有內存區域重疊。 memmove(buf2, buf1, sizeof(buf1));//內存移動,並沒有改變原始內存的值。
二維動態數組的建立和釋放
在創建動態數組的過程中我們要遵循一個原則,那就是在創建的時候從外層往裡層,逐層創建;
而釋放的時候從裡層往外層,逐層釋放。
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; }
總結
本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!