您好,登錄后才能下訂單哦!
這篇文章主要介紹“C語言動態數組詳細介紹”,在日常操作中,相信很多人在C語言動態數組詳細介紹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C語言動態數組詳細介紹”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
內存分配函數malloc calloc realloc free
內存操作函數 memset memcpy memmove
二維動態數組的建立和釋放
堆內存分配函數 | 說明 |
---|---|
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(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; }
到此,關于“C語言動態數組詳細介紹”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。