代碼本身是存儲(chǔ)在內(nèi)存的代碼段中的,而函數(shù)沒有說存儲(chǔ)的概念,函數(shù)調(diào)用時(shí)是通過棧來實(shí)現(xiàn)的。在函數(shù)體內(nèi)聲明的變量在默認(rèn)情況下都是auto存儲(chǔ)類型 在代碼塊之間傳遞信息的一種方法就是使用外部變量。
站在用戶的角度思考問題,與客戶深入溝通,找到邕寧網(wǎng)站設(shè)計(jì)與邕寧網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋邕寧地區(qū)。
對(duì)于棧來與,主函數(shù)在調(diào)用子函數(shù)之前,系統(tǒng)會(huì)自動(dòng)將主函數(shù)所使用的寄存器參數(shù)等入棧,調(diào)用子函數(shù)完畢后再將參數(shù)出棧,實(shí)現(xiàn)了主函數(shù)和子函數(shù)之間的寄存器復(fù)用功能。
函數(shù)調(diào)用時(shí),具體要保留那些數(shù)據(jù)呢,一般來說不同編譯器不同的調(diào)用方法要保留的數(shù)據(jù)都會(huì)不同。那些寄存器的值一般都會(huì)保留的,保留的數(shù)據(jù)一般是放在程序的堆棧中。
c語(yǔ)言函數(shù)調(diào)用時(shí)候,保存現(xiàn)場(chǎng)采用的是堆棧結(jié)構(gòu);當(dāng)n = 0 時(shí),當(dāng)前函數(shù)返回1;但是上一層調(diào)用的函數(shù)還在堆棧中呢,需要彈棧,直到堆棧中彈出最初函數(shù)調(diào)用時(shí)候的指針,函數(shù)才調(diào)用結(jié)束。
一切局部變量都在堆棧里保存,函數(shù)調(diào)用也在堆棧里保存返回地址。指針如果也是局部變量,也在堆棧里分配的。還有程序運(yùn)算時(shí)候也會(huì)用到堆棧。全局變量和用內(nèi)存分配函數(shù)分配的空間,則不是在堆棧里分配。
1、棧區(qū)(stack):由編譯器自動(dòng)分配釋放,存放函數(shù)的參數(shù)值,局部變量等值。局部變量,任務(wù)線程函數(shù)之類的是放在(使用)棧里面的,棧利用率高一些。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的棧。
2、棧(stack)是一種【后進(jìn)先出】的結(jié)構(gòu),例如:洗干凈的盤子總是逐個(gè)往上疊放在之前已經(jīng)寫好的盤子上,而取用的時(shí)候總是先取后洗好的放在最頂部的盤子,“棧”正是這樣一種實(shí)際的抽象。
3、下面就說說C語(yǔ)言程序內(nèi)存分配中的堆和棧,這里有必要把內(nèi)存分配也提一下,一般情況下程序存放在Rom或Flash中,運(yùn)行時(shí)需要拷到內(nèi)存中執(zhí)行,內(nèi)存會(huì)分別存儲(chǔ)不同的信息。
堆是由new分配的內(nèi)存,一般速度比較慢,而且容易產(chǎn)生內(nèi)存碎片,不過用起來最方便。存儲(chǔ)內(nèi)容 棧: 在函數(shù)調(diào)用時(shí),在大多數(shù)的C編譯器中,參數(shù)是由右往左入棧的,然后是函數(shù)中的局部變量。注意靜態(tài)變量是不入棧的。
棧區(qū)(stack)— 由編譯器自動(dòng)分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等。其操作方式類似于數(shù)據(jù)結(jié)構(gòu)中的棧。堆區(qū)(heap) — 一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時(shí)可能由OS回收 。
堆是指系統(tǒng)可以動(dòng)態(tài)申請(qǐng)和釋放的一部分究竟,這部分是可以用代碼進(jìn)行操作的。棧是函數(shù)之間調(diào)度所使用的一部分空間,這部分在代碼上沒有明顯的表示。
堆棧就是這樣一種數(shù)據(jù)結(jié)構(gòu)。它是在內(nèi)存中開辟一個(gè)存儲(chǔ)區(qū)域,數(shù)據(jù)一個(gè)一個(gè)順序地存入(也就是“壓入——push”)這個(gè)區(qū)域之中。
棧: 在函數(shù)調(diào)用時(shí),第一個(gè)進(jìn)棧的是主函數(shù)中后的下一條指令(函數(shù)調(diào)用語(yǔ)句的下一條可執(zhí)行語(yǔ)句)的地址,然后是函數(shù)的各個(gè)參數(shù),在大多數(shù)的C編譯器中,參數(shù)是由右往左入棧的,然后是函數(shù)中的局部變量。
先從大家比較熟悉的棧說起,它是一種具有后進(jìn)先出性質(zhì)的數(shù)據(jù)結(jié)構(gòu),也就是說后存放的先取,先存放的后取。
對(duì)于堆來與,可以使用malloc、realloc語(yǔ)句進(jìn)行申請(qǐng)空間,通常情況下申請(qǐng)得到的是堆空間中的一塊區(qū)域,而通常情況下定義的數(shù)組也會(huì)使用堆空間。通常情況下,由代碼申請(qǐng)得到的空間需要使用對(duì)應(yīng)的代碼進(jìn)行釋放,否則會(huì)造成內(nèi)存泄漏。
SP,#?STACK-1用來進(jìn)行堆棧分配,而?STACK作為一個(gè)變量,其值是編譯器根據(jù)你的程序自動(dòng)決定的;所以,使用keil編程不需要理會(huì)堆棧的。
棧只能夠通過出棧來減少棧中數(shù)據(jù)的個(gè)數(shù),從反面來講,如果不出棧,funcA()函數(shù)返回后,棧指針還是指向c那,這肯定是不對(duì)的,因?yàn)楹瘮?shù)返回后棧指針就得指向man()的棧結(jié)構(gòu)了。
反匯編后看匯編代碼一清二楚。當(dāng)一個(gè)父函數(shù)調(diào)用子函數(shù)時(shí),在父函數(shù)中先將子函數(shù)用到的參數(shù)壓入堆棧,然后再以一個(gè)call指令調(diào)用子函數(shù)。
比如C語(yǔ)言里面講的是結(jié)構(gòu)化程序設(shè)計(jì)的最典型的內(nèi)容。不管是哪一種教材,從一開始就注重用這種方法。
先說后一個(gè)題,c是一個(gè)STU類型的變量,用變量c做參數(shù)調(diào)用函數(shù)f時(shí),是把c的值賦值給行參a(也叫復(fù)制一份,或叫產(chǎn)生一個(gè)副本),函數(shù)f中對(duì)a的改變不會(huì)影響主函數(shù)中c的值。
while(1){ temp = scanf(%c,(&(ca)));if(ca==\n)break;...} C語(yǔ)言輸入輸出確實(shí)比較麻煩,樓主多上網(wǎng)查查,多寫寫代碼試試。數(shù)據(jù)結(jié)構(gòu)本身就是比較抽象的課程,課上認(rèn)真聽,課下多實(shí)踐。
1、在底層一點(diǎn)的匯編語(yǔ)言里面,函數(shù)調(diào)用是通過棧實(shí)現(xiàn)的,函數(shù)塊內(nèi)的變量所需的空間都在棧上分配。
2、函數(shù)調(diào)用時(shí),調(diào)用者依次把參數(shù)壓棧,然后調(diào)用函數(shù),函數(shù)被調(diào)用以后,在堆棧中取得數(shù)據(jù),并進(jìn)行計(jì)算。函數(shù)計(jì)算結(jié)束以后,或者調(diào)用者、或者函數(shù)本身修改堆棧,使堆棧恢復(fù)原裝。
3、代碼本身是存儲(chǔ)在內(nèi)存的代碼段中的,而函數(shù)沒有說存儲(chǔ)的概念,函數(shù)調(diào)用時(shí)是通過棧來實(shí)現(xiàn)的。在函數(shù)體內(nèi)聲明的變量在默認(rèn)情況下都是auto存儲(chǔ)類型 在代碼塊之間傳遞信息的一種方法就是使用外部變量。
4、這是函數(shù)的機(jī)制 函數(shù)調(diào)用用stdcall(標(biāo)準(zhǔn)調(diào)用),cdecl,fastcall等很多種調(diào)用方式。
5、每一個(gè)函數(shù)調(diào)用都會(huì)分配函數(shù)棧,在棧內(nèi)進(jìn)行函數(shù)執(zhí)行過程。調(diào)用前,先把返回地址壓棧,然后把當(dāng)前函數(shù)的esp指針壓棧。
6、程序計(jì)數(shù)器內(nèi))中保存的值計(jì)算到該函數(shù)地址的偏移量,隨后通過__cdecl等調(diào)用方式將參數(shù)和局部變量壓入棧中。具體的過程比較復(fù)雜,具體應(yīng)該參照PE結(jié)構(gòu)等。
文章標(biāo)題:c語(yǔ)言調(diào)用函數(shù)堆棧 c語(yǔ)言遞歸調(diào)用中堆棧的使用
文章路徑:http://chinadenli.net/article8/diocgip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、響應(yīng)式網(wǎng)站、小程序開發(fā)、網(wǎng)站制作、品牌網(wǎng)站設(shè)計(jì)、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容