編譯原理第五章_第1頁
編譯原理第五章_第2頁
編譯原理第五章_第3頁
編譯原理第五章_第4頁
編譯原理第五章_第5頁
已閱讀5頁,還剩44頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第5章

語法制導(dǎo)的翻譯主講:閆健恩計(jì)算機(jī)網(wǎng)絡(luò)與信息安全中心Email:yanjianen(@)1本章重點(diǎn)語法制導(dǎo)定義S屬性定義L屬性定義語法制導(dǎo)的翻譯方案設(shè)計(jì)語法制導(dǎo)定義和翻譯方案的關(guān)系自底向上實(shí)現(xiàn)L屬性的SDD2語法制導(dǎo)的翻譯5.1語法制導(dǎo)定義5.2SDD的求值順序5.3語法制導(dǎo)的翻譯方案3第五章語法制導(dǎo)的翻譯翻譯的任務(wù)首先是語義分析和正確性檢查,若正確,則翻譯成中間代碼或目標(biāo)代碼?;舅枷胝Z法結(jié)構(gòu)具有規(guī)定的語義根據(jù)翻譯的需要設(shè)置文法符號的屬性,以描述語法結(jié)構(gòu)的語義。例如,一個(gè)變量的屬性有類型,層次,存儲地址等。表達(dá)式的屬性有類型,值等。屬性值的計(jì)算和產(chǎn)生式相聯(lián)系。隨著語法分析的進(jìn)行,執(zhí)行屬性值的計(jì)算,完成語義分析和翻譯的任務(wù)。45.1語法制導(dǎo)定義1.語義分析的任務(wù)語義檢查例:類型、運(yùn)算、維數(shù)、越界語義處理例:變量的存儲分配例:表達(dá)式的求值例:語句的翻譯(中間代碼的生成)總目標(biāo):生成等價(jià)的中間代碼52.代碼結(jié)構(gòu)計(jì)算學(xué)科:對信息(數(shù)據(jù)表示)描述和變換算法的系統(tǒng)研究變換:源、目標(biāo)以及源與目標(biāo)的對應(yīng)關(guān)系語句的代碼結(jié)構(gòu)語句分類:說明語句——符號表的查填可執(zhí)行語句——指令代碼5.1語法制導(dǎo)定義63.典型處理方法(1)對應(yīng)每一個(gè)產(chǎn)生式編制一個(gè)語義子程序,當(dāng)一個(gè)產(chǎn)生式獲得匹配時(shí),調(diào)用相應(yīng)的語義子程序?qū)崿F(xiàn)語義檢查與翻譯E→E1+T E.val:=E1.val+T.valT→T1*F T.val:=T1.val*F.valF→id F.val:=id.val適宜在完成歸約的時(shí)候進(jìn)行5.1語法制導(dǎo)定義73.典型處理方法(2)在產(chǎn)生式的右部的適當(dāng)位置,插入相應(yīng)的語義動(dòng)作,按照分析的進(jìn)程,執(zhí)行遇到的語義動(dòng)作D→T{L.in:=T.type}LT→int{T.type:=integer}T→real{T.type:=real}L→{L1.in:=L.in}L1,id{…}語義——可以看成是相應(yīng)文法符號的屬性適宜在進(jìn)行推導(dǎo)時(shí)完成5.1語法制導(dǎo)定義8語義翻譯的流程輸入符號串

分析樹依賴圖語義規(guī)則的計(jì)算實(shí)際上,編譯中語義翻譯的實(shí)現(xiàn)并不是按圖中的流程處理的;而是隨語法分析的進(jìn)展,識別出一個(gè)語法結(jié)構(gòu),就對它的語義進(jìn)行分析和翻譯。94.什么是語法制導(dǎo)定義(SDD)上下文無關(guān)文法和屬性/規(guī)則的結(jié)合;屬性和文法符號相關(guān)聯(lián)規(guī)則和產(chǎn)生式相關(guān)聯(lián)根據(jù)需要,將文法符號和某些屬性相關(guān)聯(lián),并通過語義規(guī)則來描述如何計(jì)算屬性的值E→E1+T E.code=E1.code||T.code||‘+’code表示了我們關(guān)心的表達(dá)式的逆波蘭表示,規(guī)則說明加法表達(dá)式的逆波蘭表示由兩個(gè)分量的逆波蘭表示并置,然后加上‘+’得到。5.1語法制導(dǎo)定義105.語法制導(dǎo)的翻譯

在產(chǎn)生式體中加入語義動(dòng)作,并在適當(dāng)?shù)臅r(shí)候執(zhí)行這些語義動(dòng)作E→E1+T {print‘+’;}5.1語法制導(dǎo)定義11綜合屬性(synthesizedattribute):分析樹結(jié)點(diǎn)N上的非終結(jié)符號A的屬性值由N的產(chǎn)生式所關(guān)聯(lián)的語義規(guī)則來定義,又稱為S-屬性定義。必然通過N的子結(jié)點(diǎn)或N本身的屬性值來定義繼承屬性(inheritedattribute):分析樹結(jié)點(diǎn)N的屬性值由N的父結(jié)點(diǎn)所關(guān)聯(lián)的語義規(guī)則來定義。又稱為L-屬性定義。依賴于N的父結(jié)點(diǎn)、N本身和N的兄弟結(jié)點(diǎn)上的屬性值。5.1.1繼承屬性和綜合屬性12不允許N的繼承屬性通過N的子結(jié)點(diǎn)上的屬性來定義,但是允許N的綜合屬性依賴于N本身的繼承屬性。終結(jié)符號有綜合屬性(由詞法分析獲得),但是沒有繼承屬性。5.1.1繼承屬性和綜合屬性13語法制導(dǎo)定義(SDD)的例子目標(biāo):計(jì)算表達(dá)式L的值(屬性val)計(jì)算L的val值需要E的val值E的val值又依賴于E和T的val值…終結(jié)符號digit有綜合屬性lexval。14注釋語法分析樹在分析樹上求值有助于翻譯方案的可視化,便于理解。包含了各個(gè)結(jié)點(diǎn)的各屬性值的語法分析樹5.1.2翻譯方案的可視化15注釋語法分析樹構(gòu)造注釋語法分析樹步驟:對于任意的輸入串,首先構(gòu)造出相應(yīng)的分析樹。根據(jù)結(jié)點(diǎn)上的文法符號,每個(gè)結(jié)點(diǎn)都有相應(yīng)的屬性值按照分析樹中的分支對應(yīng)的文法產(chǎn)生式,應(yīng)用相應(yīng)的語義規(guī)則計(jì)算屬性值。如果某個(gè)規(guī)則N的屬性a為f(N1.b1,N2.b2,……,Nk.bk),那么我們需要先算N1.b1,N2.b2,……,Nk.bk的值。16如果可以給各個(gè)屬性值排出順序,那么這個(gè)注釋分析樹就可以計(jì)算得到。S屬性的SDD一定可以按照自底向上的方式求值。但是下面的SDD不能計(jì)算A→B A.s=B.i;B.i=A.s+1;5.1.2翻譯方案的可視化17digitlexval=3Fval=3Tval=3digitlexval=5Fval=5Tval=15*Eval=15+digitlexval=4Fval=4Tval=4Eval=19Lval=19n例5.2輸入:3*5+4n的注釋語法分析樹18適用于自頂向下分析的SDD前面的表達(dá)式文法存在直接左遞歸,因此無法直接用自頂向下方法處理。消除左遞歸之后,無法直接使用屬性val進(jìn)行處理:比如規(guī)則:T→FT’T’→*FT’T對應(yīng)的項(xiàng)中,第一個(gè)因子對應(yīng)于F,而運(yùn)算符在T’中。19相同表達(dá)式的不同文法的比較輸入串:3*4*5請觀察左邊的T對應(yīng)的部分,和右邊的T’對應(yīng)部分計(jì)算方法:把T’之外的部分的值繼承給T’。TF*digit:4digit:5TTFdigit:3F*TF*εT’TFF*digit:3digit:4T’T’digit:520適用于自頂向下分析的SDD注意:T’的屬性inh實(shí)際上是繼承了相應(yīng)的*號的左運(yùn)算分量。21例5.33*5的注釋分析樹請觀察inh屬性是如何傳遞的。225.2SDD的求值順序在對SDD的求值過程中,如果結(jié)點(diǎn)N的屬性a依賴于結(jié)點(diǎn)M1的屬性a1,M2的屬性a2,…。那么必須先計(jì)算出Mi的屬性,才能計(jì)算N的屬性a。顯然,這些值的計(jì)算順序應(yīng)該形成一個(gè)偏序關(guān)系。235.2.1依賴圖依賴圖描述了某棵特定的分析樹上的各個(gè)屬性實(shí)例之間的信息流(計(jì)算順序)從實(shí)例a1到實(shí)例a2的有向邊表示計(jì)算a2時(shí)需要a1的值。(必須先計(jì)算a2,再計(jì)算a1)24依賴圖的構(gòu)造方法for分析樹中的每個(gè)結(jié)點(diǎn)ndofor與結(jié)點(diǎn)n對應(yīng)的文法符號的每個(gè)屬性ado在依賴圖中為a構(gòu)造一個(gè)結(jié)點(diǎn);for分析樹的每個(gè)結(jié)點(diǎn)ndofor結(jié)點(diǎn)n所用產(chǎn)生式對應(yīng)的每條語義規(guī)則b:=f(c1,c2,…,ck)dofori:=1tokdo

從結(jié)點(diǎn)ci到結(jié)點(diǎn)b構(gòu)造一條有向邊;5.2.1依賴圖25例5.5依賴圖的例子3*2的注釋分析樹;T→FT’{T.val=T’.syn;

T’.inh=F.val;}邊e1、e2??赡艿挠?jì)算順序:1,2,3,4,5,6,7,8.91,3,5,2,4,6,7,8,926屬性值的計(jì)算順序可以按照依賴圖的拓?fù)渑判蛴?jì)算各個(gè)屬性的值。如果圖中存在環(huán),那么這個(gè)計(jì)算過程就無法進(jìn)行。給定一個(gè)SDD,很難判定是否存在一棵分析樹,其對應(yīng)的依賴圖包含環(huán)。但是特定類型的SDD一定不包含環(huán),且有固定的排序模式。S屬性的SDDL屬性的SDD275.2.3S屬性的SDD每個(gè)屬性都是綜合屬性都是根據(jù)子構(gòu)造的屬性計(jì)算整個(gè)構(gòu)造的屬性。在依賴圖中,總是通過子結(jié)點(diǎn)的屬性值來計(jì)算父結(jié)點(diǎn)的屬性值。可以和自頂向下、自底向上的語法分析過程一起計(jì)算自底向上:在構(gòu)造分析樹的子結(jié)點(diǎn)的同時(shí)計(jì)算相關(guān)的屬性自頂向下:遞歸子程序法中,在過程A()的最后計(jì)算A的屬性28在分析樹上計(jì)算SDD按照后序遍歷的順序計(jì)算屬性值即可postorder(N){ for(從左邊開始,對N的每個(gè)子結(jié)點(diǎn)C)

postorder(c);

對N的各個(gè)屬性求值;}在LR分析過程中,我們實(shí)際上不需要構(gòu)造分析樹的結(jié)點(diǎn)。295.2.4L屬性的SDD每個(gè)屬性要么是綜合屬性,要么是繼承屬性,且產(chǎn)生式A→X1X2…Xn中計(jì)算Xi.a的規(guī)則只能使用A的繼承屬性Xi左邊的文法符號Xj的繼承屬性或綜合屬性。Xi自身的繼承或綜合屬性。且這些屬性的依賴關(guān)系不形成環(huán)。特點(diǎn):依賴圖的邊總是從左到右,從下到上。在掃描過程中,計(jì)算一個(gè)屬性值時(shí)相關(guān)的依賴屬性都已經(jīng)計(jì)算完成了。30帶有繼承屬性L.inh的語法制導(dǎo)定義

產(chǎn)生式語義規(guī)則

DTLLinh:=TtypeTintTtype:=integerTfloatTtype:=floatLL1,idL1

inh:=Linh

addtype(id

entry,Linh)Lid

addtype(id

entry,Linh)315.2.5具有受控副作用的語義規(guī)則屬性文法沒有副作用,但是會(huì)增加描述的復(fù)雜度比如語法分析時(shí)如果沒有副作用,符號表就必須作為屬性傳遞??梢园逊柋碜鳛槿肿兞?,然后通過副作用函數(shù)來添加新標(biāo)識符;受控的副作用不會(huì)對屬性求值產(chǎn)生約束,即可以按照任何拓?fù)鋵傩郧笾?,不?huì)影響最終結(jié)果。添加部分簡單的約束。32受控副作用的例子L→En

print(E.val)通過副作用打印出E的值總是在最后執(zhí)行,且不會(huì)影響其它屬性的求值變量聲明的SDD中的副作用addType將標(biāo)識符的類型信息加入到標(biāo)識符表中。只要標(biāo)識符不被重復(fù)聲明,標(biāo)識符的類型信息總是正確的。335.3語法制導(dǎo)的翻譯方案語法制導(dǎo)的翻譯方案(SDT)是在產(chǎn)生式體中嵌入程序片斷(語義動(dòng)作)的上下文無關(guān)文法SDT的基本實(shí)現(xiàn)方法:建立語法分析樹;從左到右、深度優(yōu)先地執(zhí)行這些動(dòng)作用SDT實(shí)現(xiàn)兩類重要的SDD基本文法是LR的,SDD是S屬性的基本文法是LL的,SDD是L屬性的34可在語法分析過程中實(shí)現(xiàn)的SDT實(shí)際實(shí)現(xiàn)SDT時(shí),并不會(huì)真的構(gòu)造語法分析樹,而是在分析過程中執(zhí)行語義動(dòng)作判斷是否可在分析過程中實(shí)現(xiàn)將每個(gè)語義動(dòng)作替換為一個(gè)獨(dú)有的標(biāo)記非終結(jié)符號;每個(gè)標(biāo)記非終結(jié)符號M的產(chǎn)生式為M→ε。如果新的文法可以由某種方法進(jìn)行分析,那么這個(gè)SDT就可以在這個(gè)分析過程中實(shí)現(xiàn)。注意:這個(gè)斷言沒有考慮變量值的傳遞等要求。355.3.1后綴翻譯方案文法可以自底向上分析且SDD是S屬性的可以構(gòu)造出SDT,且所有的動(dòng)作都放在產(chǎn)生式最后;分析過程中在按照這個(gè)產(chǎn)生式歸約時(shí)執(zhí)行這個(gè)動(dòng)作;計(jì)算得到的屬性值放在棧中;所有動(dòng)作都在產(chǎn)生式最右端的SDT稱為后綴翻譯方案361后綴翻譯方案的例子實(shí)現(xiàn)桌上計(jì)算機(jī)的后綴SDT372后綴SDT的語法分析棧實(shí)現(xiàn)可以在LR語法分析的過程中實(shí)現(xiàn)歸約時(shí)執(zhí)行相應(yīng)的語義動(dòng)作定義可以記錄各個(gè)文法符號的屬性的union結(jié)構(gòu)棧中的每個(gè)文法符號(或者狀態(tài))的附帶一個(gè)這樣的結(jié)構(gòu)的值;在按照產(chǎn)生式A→XYZ歸約時(shí),Z的屬性可以在棧頂找到,Y的屬性可以在下一個(gè)位置找到,X的屬性可以在再下一個(gè)位置找到。38例5.15分析棧實(shí)現(xiàn)的例子假設(shè)語法分析棧存放在一個(gè)被稱為stack的記錄數(shù)組中,下標(biāo)top指向棧頂;stack[top]指向這個(gè)棧的棧頂;stack[top-1]指向棧頂下一個(gè)位置;如果不同的文法符號有不同的屬性集合,我們可以使用union來保存這些屬性值。(歸約時(shí),我們知道棧頂向下的各個(gè)符號分別是什么)39這個(gè)SDT中沒有局部變量,不會(huì)產(chǎn)生和局部變量有關(guān)的問題403產(chǎn)生式內(nèi)部帶有語義動(dòng)作的SDT一個(gè)動(dòng)作左部的所有符號(以及動(dòng)作)處理完成后,就立刻執(zhí)行這個(gè)動(dòng)作B→X{a}Y自底向上分析時(shí),a在X出現(xiàn)在棧頂時(shí)執(zhí)行自頂向下分析時(shí),在試圖展開Y或者在輸入中檢測到Y(jié)時(shí)執(zhí)行a不是所有的SDT都可以在分析過程中實(shí)現(xiàn)但是后綴SDT以及實(shí)現(xiàn)L屬性的SDT可以在分析時(shí)完成。對于所有的SDT,都可以先建立分析樹(語義動(dòng)作作為虛擬的結(jié)點(diǎn)),然后進(jìn)行前序遍歷并執(zhí)行動(dòng)作。414L屬性定義的SDTL屬性SDD轉(zhuǎn)換為SDT的規(guī)則:將計(jì)算非終結(jié)符號A繼承屬性的動(dòng)作放在產(chǎn)生式中緊靠A之前,如果A有多個(gè)屬性,要注意屬性計(jì)算的順序;將計(jì)算產(chǎn)生式頭的綜合屬性的動(dòng)作放在產(chǎn)生式的最右端。42例5.19L屬性的SDT的例子繼承屬性:Next:語句結(jié)束后應(yīng)該跳轉(zhuǎn)到的標(biāo)號true、false:C為真/假時(shí)應(yīng)該跳轉(zhuǎn)到的標(biāo)號綜合屬性code表示代碼435L屬性的SDD的實(shí)現(xiàn)使用遞歸下降的語法分析器每個(gè)非終結(jié)符號對應(yīng)一個(gè)函數(shù)函數(shù)的參數(shù)接受繼承屬性返回值包含了綜合屬性在函數(shù)體中,首先選擇適當(dāng)?shù)漠a(chǎn)生式使用局部變量來保存屬性對于產(chǎn)生式體中的終結(jié)符號,讀入符號并獲取其(經(jīng)詞法分析得到的)綜合屬性對于非終結(jié)符號,使用適當(dāng)?shù)姆绞秸{(diào)用相應(yīng)函數(shù),并記錄返回值。446L屬性的自底向上實(shí)現(xiàn)(1)以LL文法為基礎(chǔ)的L屬性SDD可以在LR語法分析過程中實(shí)現(xiàn)方法:首先構(gòu)造出L屬性SDD的SDT,即在非終結(jié)符號前計(jì)算其繼承屬性若有產(chǎn)生式A→α{a

溫馨提示

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

最新文檔

評論

0/150

提交評論