C語(yǔ)言 動(dòng)態(tài)內(nèi)存分配詳解
為古丈等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及古丈網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、古丈網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
動(dòng)態(tài)內(nèi)存分配涉及到堆棧的概念:堆棧是兩種數(shù)據(jù)結(jié)構(gòu)。堆棧都是數(shù)據(jù)項(xiàng)按序排列的數(shù)據(jù)結(jié)構(gòu),只能在一端(稱為棧頂(top))對(duì)數(shù)據(jù)項(xiàng)進(jìn)行插入和刪除。
棧(操作系統(tǒng)):由操作系統(tǒng)自動(dòng)分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的棧。
堆(操作系統(tǒng)):一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時(shí)可能由OS回收,分配方式倒是類似于鏈表。
\在C語(yǔ)言中,全局變量分配在內(nèi)存中的靜態(tài)存儲(chǔ)區(qū),非靜態(tài)的局部變量(包括形參)是分配在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū),該存儲(chǔ)區(qū)被稱為棧。除此之外,c語(yǔ)言還允許建立內(nèi)存動(dòng)態(tài)分配區(qū)域,以存放一些臨時(shí)用的數(shù)據(jù),這些數(shù)據(jù)不必在程序的聲明部分定義,也不必等到函數(shù)結(jié)束時(shí)才釋放,而是需要時(shí)隨時(shí)開(kāi)辟,不需要是隨時(shí)釋放。這些詩(shī)句臨時(shí)存在一個(gè)特別的自由存儲(chǔ)區(qū),稱為堆區(qū)。
系統(tǒng)提供了四個(gè)庫(kù)函數(shù)來(lái)實(shí)現(xiàn)內(nèi)存的動(dòng)態(tài)分配:
(1)malloc(size) 在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū)中分配一個(gè)長(zhǎng)度為size的連續(xù)空間。
(2)calloc(n,size) 在內(nèi)存的動(dòng)態(tài)存儲(chǔ)區(qū)中分配n個(gè)長(zhǎng)度為size的連續(xù)空間。
(3)free(p) 釋放指針變量p做指向的動(dòng)態(tài)空間。
(4)realloc(p,size) 將指針變量p指向的動(dòng)態(tài)空間大小改變?yōu)閟ize。
舉個(gè)栗子:
#include#include int main() { void check(int *); int *p1, i; p1 = (int *)malloc(5*sizeof(int)); for ( i = 0; i < 5; i++) scanf("%d",p1+i); check(p1); getchar(); getchar(); return 0; } void check(int *p) { int i; for (i = 0; i < 5; i++) if (p[i] < 60) printf("%d", p[i]); printf("\n"); }
程序沒(méi)有定義數(shù)組,而是開(kāi)辟了一段動(dòng)態(tài)自由分配區(qū),輸入數(shù)字時(shí),按照地址復(fù)制給動(dòng)態(tài)數(shù)組的5個(gè)元素,p1指向第一個(gè)整型數(shù)據(jù),調(diào)用check函數(shù)時(shí),p1作為實(shí)參傳遞給形參p,因此可以理解為形參p和實(shí)參p1公享一段動(dòng)態(tài)分配區(qū)。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!