本篇內(nèi)容介紹了“如何用C語言實(shí)現(xiàn)動態(tài)內(nèi)存分配”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
信豐ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
C語言動態(tài)內(nèi)存分配的詳解
1.為什么使用動態(tài)內(nèi)存分配
數(shù)組在使用的時(shí)候可能造成內(nèi)存浪費(fèi),使用動態(tài)內(nèi)存分配可以解決這個(gè)問題。
2. malloc和free
C函數(shù)庫提供了兩個(gè)函數(shù),malloc和free,分別用于執(zhí)行動態(tài)內(nèi)存分配和釋放。
(1)void *malloc(size_t size);
malloc的參數(shù)就是需要分配的內(nèi)存字節(jié)數(shù)。malloc分配一塊連續(xù)的內(nèi)存。如果操作系統(tǒng)無法向malloc提供更多的內(nèi)存,malloc就返回一個(gè)NULL指針。
(2)void free(void *pointer);
free的參數(shù)要么是NULL,要么是一個(gè)先前從malloc、calloc或realloc返回的值。
3. calloc和realloc
(1)void *calloc(size_t num_elements,size_t element_size);
calloc也用于內(nèi)存分配。malloc和calloc之間的主要區(qū)別是后者在返回指向內(nèi)存的指針之前把它初始化為0。
(2)realloc(void *ptr,size_t new_size);
realloc函數(shù)用于修改一個(gè)原先已經(jīng)分配的內(nèi)存塊的大小。如果它用于擴(kuò)大一個(gè)內(nèi)存,那么這塊內(nèi)存原先的內(nèi)容依然保留,新增加的內(nèi)存添加到原先內(nèi)存塊的后面。如果它用于縮小一個(gè)內(nèi)存塊,該內(nèi)存塊尾部的部分內(nèi)存被拿掉,剩余部分內(nèi)存的原先內(nèi)容依然保留。
4. 使用動態(tài)分配的內(nèi)存
(1)使用示例
int *pi; pi = malloc(25 * sizeof(int)); if(pi == NULL){ printf("out of memery\n"); exit(1); }
(2)使用間接訪問
int *pi2,i; pi2 = pi; for(i = 0;i < 25;i += 1) *pi2++ = 0;
也可以使用下標(biāo)。
int i; for(i = 0;i < 25;i += 1) *pi[i] = 0;
5. 常見的動態(tài)內(nèi)存錯(cuò)誤
常見的錯(cuò)誤有:對NULL指針進(jìn)行解引用操作、對分配的內(nèi)存進(jìn)行操作時(shí)越過邊界、釋放并非內(nèi)存分配的內(nèi)存、試圖釋放一塊動態(tài)分配的內(nèi)存的一部分以及一塊動態(tài)內(nèi)存釋放之后被繼續(xù)使用。
“如何用C語言實(shí)現(xiàn)動態(tài)內(nèi)存分配”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!