版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
第5章
語法制導(dǎo)的翻譯主講:閆健恩計算機網(wǎng)絡(luò)與信息安全中心Email:yanjianen(@)1本章重點語法制導(dǎo)定義S屬性定義L屬性定義語法制導(dǎo)的翻譯方案設(shè)計語法制導(dǎo)定義和翻譯方案的關(guān)系自底向上實現(xiàn)L屬性的SDD2語法制導(dǎo)的翻譯5.1語法制導(dǎo)定義5.2SDD的求值順序5.3語法制導(dǎo)的翻譯方案3第五章語法制導(dǎo)的翻譯翻譯的任務(wù)首先是語義分析和正確性檢查,若正確,則翻譯成中間代碼或目標(biāo)代碼。基本思想語法結(jié)構(gòu)具有規(guī)定的語義根據(jù)翻譯的需要設(shè)置文法符號的屬性,以描述語法結(jié)構(gòu)的語義。例如,一個變量的屬性有類型,層次,存儲地址等。表達式的屬性有類型,值等。屬性值的計算和產(chǎn)生式相聯(lián)系。隨著語法分析的進行,執(zhí)行屬性值的計算,完成語義分析和翻譯的任務(wù)。45.1語法制導(dǎo)定義1.語義分析的任務(wù)語義檢查例:類型、運算、維數(shù)、越界語義處理例:變量的存儲分配例:表達式的求值例:語句的翻譯(中間代碼的生成)總目標(biāo):生成等價的中間代碼52.代碼結(jié)構(gòu)計算學(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)每一個產(chǎn)生式編制一個語義子程序,當(dāng)一個產(chǎn)生式獲得匹配時,調(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適宜在完成歸約的時候進行5.1語法制導(dǎo)定義73.典型處理方法(2)在產(chǎn)生式的右部的適當(dāng)位置,插入相應(yīng)的語義動作,按照分析的進程,執(zhí)行遇到的語義動作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)文法符號的屬性適宜在進行推導(dǎo)時完成5.1語法制導(dǎo)定義8語義翻譯的流程輸入符號串
分析樹依賴圖語義規(guī)則的計算實際上,編譯中語義翻譯的實現(xiàn)并不是按圖中的流程處理的;而是隨語法分析的進展,識別出一個語法結(jié)構(gòu),就對它的語義進行分析和翻譯。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ī)則來描述如何計算屬性的值E→E1+T E.code=E1.code||T.code||‘+’code表示了我們關(guān)心的表達式的逆波蘭表示,規(guī)則說明加法表達式的逆波蘭表示由兩個分量的逆波蘭表示并置,然后加上‘+’得到。5.1語法制導(dǎo)定義105.語法制導(dǎo)的翻譯
在產(chǎn)生式體中加入語義動作,并在適當(dāng)?shù)臅r候執(zhí)行這些語義動作E→E1+T {print‘+’;}5.1語法制導(dǎo)定義11綜合屬性(synthesizedattribute):分析樹結(jié)點N上的非終結(jié)符號A的屬性值由N的產(chǎn)生式所關(guān)聯(lián)的語義規(guī)則來定義,又稱為S-屬性定義。必然通過N的子結(jié)點或N本身的屬性值來定義繼承屬性(inheritedattribute):分析樹結(jié)點N的屬性值由N的父結(jié)點所關(guān)聯(lián)的語義規(guī)則來定義。又稱為L-屬性定義。依賴于N的父結(jié)點、N本身和N的兄弟結(jié)點上的屬性值。5.1.1繼承屬性和綜合屬性12不允許N的繼承屬性通過N的子結(jié)點上的屬性來定義,但是允許N的綜合屬性依賴于N本身的繼承屬性。終結(jié)符號有綜合屬性(由詞法分析獲得),但是沒有繼承屬性。5.1.1繼承屬性和綜合屬性13語法制導(dǎo)定義(SDD)的例子目標(biāo):計算表達式L的值(屬性val)計算L的val值需要E的val值E的val值又依賴于E和T的val值…終結(jié)符號digit有綜合屬性lexval。14注釋語法分析樹在分析樹上求值有助于翻譯方案的可視化,便于理解。包含了各個結(jié)點的各屬性值的語法分析樹5.1.2翻譯方案的可視化15注釋語法分析樹構(gòu)造注釋語法分析樹步驟:對于任意的輸入串,首先構(gòu)造出相應(yīng)的分析樹。根據(jù)結(jié)點上的文法符號,每個結(jié)點都有相應(yīng)的屬性值按照分析樹中的分支對應(yīng)的文法產(chǎn)生式,應(yīng)用相應(yīng)的語義規(guī)則計算屬性值。如果某個規(guī)則N的屬性a為f(N1.b1,N2.b2,……,Nk.bk),那么我們需要先算N1.b1,N2.b2,……,Nk.bk的值。16如果可以給各個屬性值排出順序,那么這個注釋分析樹就可以計算得到。S屬性的SDD一定可以按照自底向上的方式求值。但是下面的SDD不能計算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前面的表達式文法存在直接左遞歸,因此無法直接用自頂向下方法處理。消除左遞歸之后,無法直接使用屬性val進行處理:比如規(guī)則:T→FT’T’→*FT’T對應(yīng)的項中,第一個因子對應(yīng)于F,而運算符在T’中。19相同表達式的不同文法的比較輸入串:3*4*5請觀察左邊的T對應(yīng)的部分,和右邊的T’對應(yīng)部分計算方法:把T’之外的部分的值繼承給T’。TF*digit:4digit:5TTFdigit:3F*TF*εT’TFF*digit:3digit:4T’T’digit:520適用于自頂向下分析的SDD注意:T’的屬性inh實際上是繼承了相應(yīng)的*號的左運算分量。21例5.33*5的注釋分析樹請觀察inh屬性是如何傳遞的。225.2SDD的求值順序在對SDD的求值過程中,如果結(jié)點N的屬性a依賴于結(jié)點M1的屬性a1,M2的屬性a2,…。那么必須先計算出Mi的屬性,才能計算N的屬性a。顯然,這些值的計算順序應(yīng)該形成一個偏序關(guān)系。235.2.1依賴圖依賴圖描述了某棵特定的分析樹上的各個屬性實例之間的信息流(計算順序)從實例a1到實例a2的有向邊表示計算a2時需要a1的值。(必須先計算a2,再計算a1)24依賴圖的構(gòu)造方法for分析樹中的每個結(jié)點ndofor與結(jié)點n對應(yīng)的文法符號的每個屬性ado在依賴圖中為a構(gòu)造一個結(jié)點;for分析樹的每個結(jié)點ndofor結(jié)點n所用產(chǎn)生式對應(yīng)的每條語義規(guī)則b:=f(c1,c2,…,ck)dofori:=1tokdo
從結(jié)點ci到結(jié)點b構(gòu)造一條有向邊;5.2.1依賴圖25例5.5依賴圖的例子3*2的注釋分析樹;T→FT’{T.val=T’.syn;
T’.inh=F.val;}邊e1、e2。可能的計算順序:1,2,3,4,5,6,7,8.91,3,5,2,4,6,7,8,926屬性值的計算順序可以按照依賴圖的拓?fù)渑判蛴嬎愀鱾€屬性的值。如果圖中存在環(huán),那么這個計算過程就無法進行。給定一個SDD,很難判定是否存在一棵分析樹,其對應(yīng)的依賴圖包含環(huán)。但是特定類型的SDD一定不包含環(huán),且有固定的排序模式。S屬性的SDDL屬性的SDD275.2.3S屬性的SDD每個屬性都是綜合屬性都是根據(jù)子構(gòu)造的屬性計算整個構(gòu)造的屬性。在依賴圖中,總是通過子結(jié)點的屬性值來計算父結(jié)點的屬性值。可以和自頂向下、自底向上的語法分析過程一起計算自底向上:在構(gòu)造分析樹的子結(jié)點的同時計算相關(guān)的屬性自頂向下:遞歸子程序法中,在過程A()的最后計算A的屬性28在分析樹上計算SDD按照后序遍歷的順序計算屬性值即可postorder(N){ for(從左邊開始,對N的每個子結(jié)點C)
postorder(c);
對N的各個屬性求值;}在LR分析過程中,我們實際上不需要構(gòu)造分析樹的結(jié)點。295.2.4L屬性的SDD每個屬性要么是綜合屬性,要么是繼承屬性,且產(chǎn)生式A→X1X2…Xn中計算Xi.a的規(guī)則只能使用A的繼承屬性Xi左邊的文法符號Xj的繼承屬性或綜合屬性。Xi自身的繼承或綜合屬性。且這些屬性的依賴關(guān)系不形成環(huán)。特點:依賴圖的邊總是從左到右,從下到上。在掃描過程中,計算一個屬性值時相關(guān)的依賴屬性都已經(jīng)計算完成了。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ī)則屬性文法沒有副作用,但是會增加描述的復(fù)雜度比如語法分析時如果沒有副作用,符號表就必須作為屬性傳遞。可以把符號表作為全局變量,然后通過副作用函數(shù)來添加新標(biāo)識符;受控的副作用不會對屬性求值產(chǎn)生約束,即可以按照任何拓?fù)鋵傩郧笾担粫绊懽罱K結(jié)果。添加部分簡單的約束。32受控副作用的例子L→En
print(E.val)通過副作用打印出E的值總是在最后執(zhí)行,且不會影響其它屬性的求值變量聲明的SDD中的副作用addType將標(biāo)識符的類型信息加入到標(biāo)識符表中。只要標(biāo)識符不被重復(fù)聲明,標(biāo)識符的類型信息總是正確的。335.3語法制導(dǎo)的翻譯方案語法制導(dǎo)的翻譯方案(SDT)是在產(chǎn)生式體中嵌入程序片斷(語義動作)的上下文無關(guān)文法SDT的基本實現(xiàn)方法:建立語法分析樹;從左到右、深度優(yōu)先地執(zhí)行這些動作用SDT實現(xiàn)兩類重要的SDD基本文法是LR的,SDD是S屬性的基本文法是LL的,SDD是L屬性的34可在語法分析過程中實現(xiàn)的SDT實際實現(xiàn)SDT時,并不會真的構(gòu)造語法分析樹,而是在分析過程中執(zhí)行語義動作判斷是否可在分析過程中實現(xiàn)將每個語義動作替換為一個獨有的標(biāo)記非終結(jié)符號;每個標(biāo)記非終結(jié)符號M的產(chǎn)生式為M→ε。如果新的文法可以由某種方法進行分析,那么這個SDT就可以在這個分析過程中實現(xiàn)。注意:這個斷言沒有考慮變量值的傳遞等要求。355.3.1后綴翻譯方案文法可以自底向上分析且SDD是S屬性的可以構(gòu)造出SDT,且所有的動作都放在產(chǎn)生式最后;分析過程中在按照這個產(chǎn)生式歸約時執(zhí)行這個動作;計算得到的屬性值放在棧中;所有動作都在產(chǎn)生式最右端的SDT稱為后綴翻譯方案361后綴翻譯方案的例子實現(xiàn)桌上計算機的后綴SDT372后綴SDT的語法分析棧實現(xiàn)可以在LR語法分析的過程中實現(xiàn)歸約時執(zhí)行相應(yīng)的語義動作定義可以記錄各個文法符號的屬性的union結(jié)構(gòu)棧中的每個文法符號(或者狀態(tài))的附帶一個這樣的結(jié)構(gòu)的值;在按照產(chǎn)生式A→XYZ歸約時,Z的屬性可以在棧頂找到,Y的屬性可以在下一個位置找到,X的屬性可以在再下一個位置找到。38例5.15分析棧實現(xiàn)的例子假設(shè)語法分析棧存放在一個被稱為stack的記錄數(shù)組中,下標(biāo)top指向棧頂;stack[top]指向這個棧的棧頂;stack[top-1]指向棧頂下一個位置;如果不同的文法符號有不同的屬性集合,我們可以使用union來保存這些屬性值。(歸約時,我們知道棧頂向下的各個符號分別是什么)39這個SDT中沒有局部變量,不會產(chǎn)生和局部變量有關(guān)的問題403產(chǎn)生式內(nèi)部帶有語義動作的SDT一個動作左部的所有符號(以及動作)處理完成后,就立刻執(zhí)行這個動作B→X{a}Y自底向上分析時,a在X出現(xiàn)在棧頂時執(zhí)行自頂向下分析時,在試圖展開Y或者在輸入中檢測到Y(jié)時執(zhí)行a不是所有的SDT都可以在分析過程中實現(xiàn)但是后綴SDT以及實現(xiàn)L屬性的SDT可以在分析時完成。對于所有的SDT,都可以先建立分析樹(語義動作作為虛擬的結(jié)點),然后進行前序遍歷并執(zhí)行動作。414L屬性定義的SDTL屬性SDD轉(zhuǎn)換為SDT的規(guī)則:將計算非終結(jié)符號A繼承屬性的動作放在產(chǎn)生式中緊靠A之前,如果A有多個屬性,要注意屬性計算的順序;將計算產(chǎn)生式頭的綜合屬性的動作放在產(chǎn)生式的最右端。42例5.19L屬性的SDT的例子繼承屬性:Next:語句結(jié)束后應(yīng)該跳轉(zhuǎn)到的標(biāo)號true、false:C為真/假時應(yīng)該跳轉(zhuǎn)到的標(biāo)號綜合屬性code表示代碼435L屬性的SDD的實現(xiàn)使用遞歸下降的語法分析器每個非終結(jié)符號對應(yīng)一個函數(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屬性的自底向上實現(xiàn)(1)以LL文法為基礎(chǔ)的L屬性SDD可以在LR語法分析過程中實現(xiàn)方法:首先構(gòu)造出L屬性SDD的SDT,即在非終結(jié)符號前計算其繼承屬性若有產(chǎn)生式A→α{a
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025飯店轉(zhuǎn)包合同范文
- 2025年度養(yǎng)老機構(gòu)寵物養(yǎng)護服務(wù)合同示范文本3篇
- 二零二五年度競業(yè)禁止勞動合同在文化產(chǎn)業(yè)的關(guān)鍵作用3篇
- 二零二五年度公租房合同簽訂及補貼發(fā)放協(xié)議3篇
- 二零二五年度學(xué)校食堂兼職校醫(yī)食品安全合同2篇
- 二零二五年度素食餐飲技術(shù)加盟經(jīng)營合同2篇
- 二零二五年度土方運輸車輛智能化改造與升級合同3篇
- 二零二五年度新能源電動汽車租賃合同2篇
- 2025年度年度租賃車輛保險責(zé)任協(xié)議3篇
- 2025年度極限運動賽事委托承辦授權(quán)協(xié)議3篇
- 裝飾裝修工程質(zhì)量保證措施和創(chuàng)優(yōu)計劃
- 內(nèi)鏡室院感知識培訓(xùn)
- 吃動平衡知識講座
- 漏工序改善控制方案
- 數(shù)據(jù)維護方案
- 湖北省部分學(xué)校2023-2024學(xué)年高一上學(xué)期期末考試數(shù)學(xué)試題(解析版)
- 軟件測試人員述職報告
- 《內(nèi)經(jīng)選讀》期末考試參考題庫(含答案)
- 廣東省佛山市2023-2024學(xué)年高二上學(xué)期期末中教學(xué)質(zhì)量檢測英語試題【含答案解析】
- 器械相關(guān)感染預(yù)防課件
- 2024年度醫(yī)院影像科護理工作計劃
評論
0/150
提交評論