編譯原理實(shí)踐8-運(yùn)行時(shí)的存儲(chǔ)組織與分配_第1頁(yè)
編譯原理實(shí)踐8-運(yùn)行時(shí)的存儲(chǔ)組織與分配_第2頁(yè)
編譯原理實(shí)踐8-運(yùn)行時(shí)的存儲(chǔ)組織與分配_第3頁(yè)
編譯原理實(shí)踐8-運(yùn)行時(shí)的存儲(chǔ)組織與分配_第4頁(yè)
編譯原理實(shí)踐8-運(yùn)行時(shí)的存儲(chǔ)組織與分配_第5頁(yè)
已閱讀5頁(yè),還剩24頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

編譯原理實(shí)踐

--運(yùn)行時(shí)的存儲(chǔ)組織與分配在程序的執(zhí)行過(guò)程中,程序中數(shù)據(jù)的存取是通過(guò)對(duì)應(yīng)的存儲(chǔ)單元進(jìn)行的。在早期的計(jì)算機(jī)上,這個(gè)存儲(chǔ)管理工作是由程序員自己來(lái)完成。在程序執(zhí)行以前,首先要將用機(jī)器語(yǔ)言或匯編語(yǔ)言編寫(xiě)的程序輸送到內(nèi)存的某個(gè)指定區(qū)域中,并預(yù)先給變量和數(shù)據(jù)分配相應(yīng)的內(nèi)存地址。而有了高級(jí)語(yǔ)言之后,程序員不必直接和內(nèi)存地址打交道,程序中使用的存儲(chǔ)單元都由邏輯變量(標(biāo)識(shí)符)來(lái)表示,它們對(duì)應(yīng)的內(nèi)存地址都是由編譯程序在編譯時(shí)分配或由其生成的目標(biāo)程序運(yùn)行時(shí)進(jìn)行分配。所以,對(duì)編譯程序來(lái)說(shuō),存儲(chǔ)的組織及管理是一個(gè)復(fù)雜而又十分重要的問(wèn)題。另外,有些程序設(shè)計(jì)語(yǔ)言允許有遞歸過(guò)程,有的允許有可變長(zhǎng)度的串,有的允許有動(dòng)態(tài)數(shù)組,而有些語(yǔ)言則不允許有這些,為什么呢?這都是因?yàn)椴捎昧瞬煌拇鎯?chǔ)分配方式。1、存儲(chǔ)組織概述程序運(yùn)行時(shí),系統(tǒng)將為程序分配一塊存儲(chǔ)空間。這塊空間用來(lái)存儲(chǔ)程序的目標(biāo)代碼以及目標(biāo)代碼運(yùn)行時(shí)需要或產(chǎn)生的各種數(shù)據(jù):1)

目標(biāo)程序區(qū):用來(lái)存放目標(biāo)代碼。2)

靜態(tài)數(shù)據(jù)區(qū):用來(lái)存放編譯時(shí)就能確定存儲(chǔ)空間的數(shù)據(jù)。3)

運(yùn)行棧區(qū):用來(lái)存放運(yùn)行時(shí)才能確定存儲(chǔ)空間的數(shù)據(jù)。4)

運(yùn)行堆區(qū):用來(lái)存放運(yùn)行時(shí)用戶動(dòng)態(tài)申請(qǐng)存儲(chǔ)空間的數(shù)據(jù)。運(yùn)行時(shí)存儲(chǔ)空間的劃分目標(biāo)代碼區(qū)靜態(tài)數(shù)據(jù)區(qū)棧自由空間堆存儲(chǔ)分配策略靜態(tài)存儲(chǔ)分配在運(yùn)行前就能確定數(shù)據(jù)空間的大小,因而在編譯時(shí)就能分配各種數(shù)據(jù)項(xiàng)的空間,如FORTRAN語(yǔ)言動(dòng)態(tài)存儲(chǔ)分配 不能在編譯時(shí)完全確定所有數(shù)據(jù)項(xiàng)的存儲(chǔ)空間,只能在編譯時(shí)產(chǎn)生各種必要的信息,而在運(yùn)行時(shí),再動(dòng)態(tài)地分配數(shù)據(jù)項(xiàng)的存儲(chǔ)空間。包括棧式動(dòng)態(tài)存儲(chǔ)分配和堆式動(dòng)態(tài)存儲(chǔ)分配1)棧式動(dòng)態(tài)存儲(chǔ)分配:運(yùn)行時(shí),每當(dāng)進(jìn)入一個(gè)分程序或過(guò)程,其中各項(xiàng)數(shù)據(jù)項(xiàng)所需的存儲(chǔ)空間就動(dòng)態(tài)地分配于棧頂,退出時(shí),則釋放所占用的空間特點(diǎn):效率很高,但是分配的內(nèi)存容量有限2)堆式動(dòng)態(tài)存儲(chǔ)分配: 允許用戶動(dòng)態(tài)申請(qǐng)存儲(chǔ)空間,每當(dāng)需要時(shí)可從堆中分得一塊,用完之后再退還給堆特點(diǎn):動(dòng)態(tài)內(nèi)存的生存期由我們決定,使用非常靈活,但問(wèn)題也最多注意:我們接下來(lái)只討論棧式動(dòng)態(tài)存儲(chǔ)分配棧式動(dòng)態(tài)存儲(chǔ)分配在允許遞歸調(diào)用的語(yǔ)言中,每次遞歸調(diào)用都要重新分配局部變量。對(duì)于這種語(yǔ)言應(yīng)該采用“棧式動(dòng)態(tài)存儲(chǔ)分配”,其分配策略是將整個(gè)程序的數(shù)據(jù)空間設(shè)計(jì)為一個(gè)棧,每當(dāng)調(diào)用一個(gè)過(guò)程時(shí)就將其活動(dòng)記錄壓入棧,在棧頂形成該過(guò)程工作時(shí)的數(shù)據(jù)區(qū),而當(dāng)過(guò)程結(jié)束時(shí)再將其活動(dòng)記錄彈出棧。在這種分配方式下,過(guò)程的調(diào)用關(guān)系是先進(jìn)后出的棧模型,每個(gè)過(guò)程都可能有若干個(gè)不同的活動(dòng)記錄,每個(gè)活動(dòng)記錄代表了一次不同的調(diào)用。當(dāng)前的AR首地址由棧指針SP指出。AR中通常應(yīng)包含如下內(nèi)容:被調(diào)用過(guò)程非局部變量存儲(chǔ)區(qū)的首地址(靜態(tài)鏈、Display表)調(diào)用過(guò)程的AR首址(動(dòng)態(tài)鏈,oldSP)調(diào)用點(diǎn)的機(jī)器狀態(tài)形實(shí)參數(shù)通訊區(qū)返回值被調(diào)用過(guò)程的局部量和臨時(shí)變量存儲(chǔ)區(qū)返回指針returnedpointer動(dòng)態(tài)鏈dynamiclink靜態(tài)鏈staticlink機(jī)器狀態(tài)machinestates參數(shù)單元parameters局部變量localvariables臨時(shí)變量temporaries高地址低地址mainpQ callQ callQ

callpSPmain’sARp’sARQ’sAR(1)Q’sAR(2)棧增長(zhǎng)方向過(guò)程的一次執(zhí)行對(duì)應(yīng)一個(gè)AR1)簡(jiǎn)單語(yǔ)言的棧式存儲(chǔ)分配簡(jiǎn)單語(yǔ)言:無(wú)分程序結(jié)構(gòu),過(guò)程定義不嵌套,但允許過(guò)程的遞歸調(diào)用。如C語(yǔ)言。C語(yǔ)言不允許過(guò)程嵌套定義,即不允許在一個(gè)過(guò)程內(nèi)定義另一個(gè)過(guò)程。C語(yǔ)言的全局變量只能出現(xiàn)在源程序的開(kāi)頭,可采用靜態(tài)存儲(chǔ)分配,編譯時(shí)候就確定它們的地址計(jì)算局部變量或形參絕對(duì)地址的公式為:絕對(duì)地址=SP+相對(duì)地址比較簡(jiǎn)單,具體不再討論2)嵌套過(guò)程語(yǔ)言的棧式存儲(chǔ)分配嵌套過(guò)程語(yǔ)言:允許過(guò)程嵌套,如pascal,PL/0。AR中必須有一些內(nèi)容,用于解決對(duì)非局部變量的引用問(wèn)題“嵌套層次”,或稱層數(shù)。主程序?yàn)?,過(guò)程S在層數(shù)為i的過(guò)程R定義,則S層數(shù)為i+1一個(gè)過(guò)程可以引用包圍它的任一外層過(guò)程所定義的變量,解決方法很多,常見(jiàn)的方法:雙指針?lè)椒ê虳isplay表方法雙指針?lè)椒ê?jiǎn)單直接,但當(dāng)嵌套層次較多時(shí),對(duì)非局部量的訪問(wèn)效率較低!Display表方法效率較高,實(shí)現(xiàn)略復(fù)雜對(duì)于PL/0的編譯程序,采用的是雙指針?lè)椒≒L/0數(shù)據(jù)動(dòng)態(tài)存儲(chǔ)采用的技術(shù)措施編譯時(shí)為每一變量名、過(guò)程名和程序段確定一個(gè)反映靜態(tài)嵌套深度的級(jí)別level調(diào)用一個(gè)過(guò)程時(shí),把他的活動(dòng)記錄壓入運(yùn)行時(shí)的棧頂,返回時(shí)彈出相應(yīng)的活動(dòng)記錄。活動(dòng)記錄包括:靜態(tài)鏈接SL:指向定義該過(guò)程的直接外層過(guò)程的活動(dòng)記錄的基地址,以確保變量的正確存取動(dòng)態(tài)鏈接DL:指向調(diào)用該過(guò)程前正在運(yùn)行的那個(gè)過(guò)程的活動(dòng)紀(jì)錄的基地址,以確保能返回到調(diào)用過(guò)程段返回地址RA:保存該被調(diào)用過(guò)程返回后的地址,也就是調(diào)用過(guò)程指令的下一條指令的地址為過(guò)程局部變量預(yù)留的存儲(chǔ)單元所有運(yùn)算操作都從棧頂找到它的操作數(shù),并以計(jì)算結(jié)果代之編譯原理實(shí)踐

--目標(biāo)計(jì)算機(jī)及其解釋程序當(dāng)前任務(wù):將PL/0源程序翻譯成為目標(biāo)代碼程序通常先將源程序翻譯成一種中間代碼程序,然后再對(duì)中間代碼程序進(jìn)行處理將中間代碼程序翻譯成某一種計(jì)算機(jī)的匯編指令程序,由該計(jì)算機(jī)的匯編程序?qū)ι傻膮R編指令程序匯編,獲得可以在該計(jì)算機(jī)上執(zhí)行的目標(biāo)程序編寫(xiě)一個(gè)獨(dú)立的解釋程序,解釋執(zhí)行生成的中間代碼程序PL/0編譯程序不僅完成通常的詞法分析、語(yǔ)法分析,而且還產(chǎn)生中間代碼和“目標(biāo)”代碼。最終我們要“運(yùn)行”該目標(biāo)碼。為了不致陷入與本課程無(wú)關(guān)的實(shí)際機(jī)器的特有性質(zhì)的考慮中去,我們假想有臺(tái)適合PL/0程序運(yùn)行的計(jì)算機(jī),我們稱之為PL/0處理機(jī)。PL/0處理機(jī)順序解釋生成的目標(biāo)代碼,我們稱之為解釋程序。注意:這里的假設(shè)與我們的編譯概念并不矛盾,在本課程中我們寫(xiě)的只是一個(gè)示范性的編譯程序,它的后端無(wú)法完整地實(shí)現(xiàn),因而只能在一個(gè)解釋性的環(huán)境下予以模擬。從另一個(gè)角度上講,把解釋程序就看成是PL/0機(jī)硬件,把解釋執(zhí)行看成是PL/0的硬件執(zhí)行,那么我們所做的工作:由PL/0源語(yǔ)言程序到PL/0機(jī)器指令的變換,就是一個(gè)完整的編譯程序。目標(biāo)計(jì)算機(jī)的組織結(jié)構(gòu)和指令格式數(shù)據(jù)存儲(chǔ)器的動(dòng)態(tài)存儲(chǔ)器管理目標(biāo)計(jì)算機(jī)指令系統(tǒng)及其解釋解釋程序interpret及其執(zhí)行1.目標(biāo)計(jì)算機(jī)的組織結(jié)構(gòu)和指令格式目標(biāo)計(jì)算機(jī)的組織結(jié)構(gòu)程序存儲(chǔ)器code數(shù)據(jù)存儲(chǔ)器s程序地址寄存器p地址寄存器t指令寄存器i基本地址寄存器b目標(biāo)計(jì)算機(jī)的指令結(jié)構(gòu)LIT指令,把一個(gè)常數(shù)放入棧頂LOD指令,把一個(gè)變量放入棧頂STO指令,從棧頂把數(shù)放入一個(gè)變量單元里CAL指令,調(diào)用一個(gè)過(guò)程INT指令,預(yù)留數(shù)據(jù)存儲(chǔ)位置JMP指令,無(wú)條件轉(zhuǎn)移JPC指令,有條件轉(zhuǎn)移OPR一組算術(shù)和關(guān)系運(yùn)算指令PL/0計(jì)算機(jī)的指令格式FLAINT———常量LIT———常量LOD層次差數(shù)據(jù)地址STO層次差數(shù)據(jù)地址CAL層次差程序地址JMP———程序地址JPC———程序地址OPR———運(yùn)算類(lèi)別層次差為變量名或過(guò)程名引用和聲明之間的靜態(tài)層次差別,程序地址為目標(biāo)數(shù)組code的下標(biāo),數(shù)據(jù)地址為變量在局部存貯中的相對(duì)地址PL/0的編譯程序?yàn)槊恳粭lPL/0源程序的可執(zhí)行語(yǔ)句生成后綴式目標(biāo)代碼。這種代碼生成方式對(duì)于表達(dá)式、賦值語(yǔ)句、過(guò)程調(diào)用等的翻譯較簡(jiǎn)單如賦值語(yǔ)句X:=YopZ(op為某個(gè)運(yùn)算符),將被翻譯成下面的目標(biāo)代碼序列:(設(shè)指令計(jì)數(shù)從第100號(hào)開(kāi)始)100LODLevel_diff_Y,Addr_Y101LODLevel_diff_Z,Addr_Z102OPR0,op103STOLevel_diff_X,Addr_X2.數(shù)據(jù)存儲(chǔ)器的動(dòng)態(tài)存儲(chǔ)器管理每一個(gè)PL/0過(guò)程可能含有局部變量。過(guò)程可以遞歸調(diào)用,每次遞歸調(diào)用,被調(diào)用過(guò)程又要求有自己的局部變量,因此不可能在編譯時(shí)就為局部變量確定好固定的存儲(chǔ)位置。只能在每次執(zhí)行過(guò)程調(diào)用時(shí)才為過(guò)程的一組局部變量確定相應(yīng)的存儲(chǔ)位置。過(guò)程一結(jié)束,存儲(chǔ)位置又被釋放。后進(jìn)先出—lastinfirstout按照棧的原理來(lái)管理數(shù)據(jù)存儲(chǔ)器數(shù)據(jù)動(dòng)態(tài)存儲(chǔ)分析在調(diào)用一個(gè)過(guò)程時(shí),先在棧頂為過(guò)程及其變量分配一些位置,叫做過(guò)程段每個(gè)過(guò)程在過(guò)程段里存放一些自己的數(shù)據(jù),至少有被調(diào)用時(shí)的程序地址RA(返回地址)以及調(diào)用過(guò)程的段地址DL(動(dòng)態(tài)鏈接)還需要有第二個(gè)鏈,能正確反映變量存取的路線,稱為SL(靜態(tài)鏈接)地址于是由編譯程序表示為數(shù)據(jù)對(duì)l和a的形式。第一個(gè)數(shù)l表示調(diào)用者(調(diào)用程序段)與被調(diào)用變量之間的靜態(tài)級(jí)差,它等于找到變量所在段須通過(guò)的SL鏈的個(gè)數(shù)。第二個(gè)數(shù)a是位移,即變量在所在段的相對(duì)地址程序靜態(tài)級(jí)別和動(dòng)態(tài)存儲(chǔ)分配編譯程序在編譯過(guò)程中能為程序的每一個(gè)變量名、過(guò)程名以及程序段分配一個(gè)靜態(tài)嵌套深度,或者說(shuō)靜態(tài)級(jí)別調(diào)用語(yǔ)句被翻譯成call,a,其中a是被調(diào)用代碼程序在程序存儲(chǔ)器的開(kāi)始地址,l是調(diào)用程序段的級(jí)與被調(diào)用過(guò)程的級(jí)之差函數(shù)base(l)數(shù)據(jù)動(dòng)態(tài)存儲(chǔ)采用的技術(shù)措施編譯時(shí)為每一變量名、過(guò)程名和程序段確定一個(gè)反映靜態(tài)嵌套深度的級(jí)別level采用數(shù)據(jù)棧的管

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論