您好,登錄后才能下訂單哦!
這篇文章主要介紹“C語言動(dòng)態(tài)數(shù)組詳細(xì)介紹”,在日常操作中,相信很多人在C語言動(dòng)態(tài)數(shù)組詳細(xì)介紹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C語言動(dòng)態(tài)數(shù)組詳細(xì)介紹”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
內(nèi)存分配函數(shù)malloc calloc realloc free
內(nèi)存操作函數(shù) memset memcpy memmove
二維動(dòng)態(tài)數(shù)組的建立和釋放
堆內(nèi)存分配函數(shù) | 說明 |
---|---|
void * malloc(int n) | 形參n為要求分配的字節(jié)數(shù)。需要注意的是,malloc函數(shù)分配得到的內(nèi)存空間是未初始化的。必須使用memset函數(shù)來初始化。 |
calloc(10, sizeof(char)); | 兩個(gè)參數(shù):單元數(shù),單元的size。分配內(nèi)存,并清理內(nèi)存。初始內(nèi)容全部為0; |
realloc(p,10); | 調(diào)整內(nèi)存的大??; 分配的內(nèi)存空間并未初始化;使用新返回的地址, |
free(void * p) | 釋放指針p所指向的堆上的空間; |
malloc() 不對分配的內(nèi)存空間做初始化,內(nèi)存上原有的值不會(huì)被清理。
realloc(),在原有內(nèi)存基礎(chǔ)之上,在堆中間增加連續(xù)的內(nèi)存,如果原有內(nèi)存沒有連續(xù)空間可擴(kuò)展,則新分配一個(gè)空間,將原有內(nèi)存copy到新空間,然后釋放原有內(nèi)存。
p = malloc(10); //直接申請4k的空間。內(nèi)存頁大小。 返回值是無類型指針void *,可以強(qiáng)制轉(zhuǎn)換。 free(p); char *p = calloc(10, sizeof(char)); //兩個(gè)參數(shù):單元數(shù),單元的size。 分配內(nèi)存,并清理內(nèi)存 char *p2 = realloc(p,10); // 在原有內(nèi)存基礎(chǔ)之上,在堆中間增加連續(xù)的內(nèi)存,如果原有內(nèi)存沒有連續(xù)空間可擴(kuò)展,則新分配一個(gè)空間,將原有內(nèi)存copy到新空間,然后釋放原有內(nèi)存。 char *p2 = realloc(NULL,20); //此時(shí),和malloc等價(jià)
realloc和malloc一樣,只分配內(nèi)存,不清理,需要手動(dòng)初始化。
// 復(fù)雜數(shù)據(jù)內(nèi)存放在堆里面
memset(buf,0,sizeof(buf));//三個(gè)參數(shù)分別是:要設(shè)置的內(nèi)存地址,要設(shè)置的值,值占的內(nèi)存的字節(jié)數(shù)。 將一塊內(nèi)存初始化為0最長見的方法。 extern void *memset(void *buffer, int c, int count) memcpy(void *dest,void *src,unsigned int count);//將buf1的地址的內(nèi)存內(nèi)容全部拷貝到buf2,拷貝大小為第三個(gè)參數(shù):字節(jié)一定確保內(nèi)存區(qū)域沒有內(nèi)存區(qū)域重疊。 memmove(buf2, buf1, sizeof(buf1));//內(nèi)存移動(dòng),并沒有改變原始內(nèi)存的值。
在創(chuàng)建動(dòng)態(tài)數(shù)組的過程中我們要遵循一個(gè)原則,那就是在創(chuàng)建的時(shí)候從外層往里層,逐層創(chuàng)建;
而釋放的時(shí)候從里層往外層,逐層釋放。
int main() { int num1,num2; num1 = 4; num2 = 5; int **array = (int **)calloc(num1,sizeof(int *));//開辟空間,num1個(gè)一維int*型指針 for(int i=0;i<num1;i++) { array[i] = (int *)calloc(num2,sizeof(int)); //給每個(gè)int *型指針分配內(nèi)存 } 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]); // 釋放第二維的內(nèi)存 } free(array); // 釋放第一維的內(nèi)存 return 0; }
到此,關(guān)于“C語言動(dòng)態(tài)數(shù)組詳細(xì)介紹”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。