版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
編譯原理(第三版)
陳火旺等編著(2015年9月-10月)主講:朱世松計算機學院22023/2/3概述一、語義分析的任務(wù)審查每一個語法結(jié)構(gòu)的靜態(tài)語義,即驗證語法正確的結(jié)構(gòu)是否有意義。 如:賦值語句:x=x+y,左邊變量類型與右邊變量類型是否一致。在語義正確的基礎(chǔ)上生成一種中間代碼或目標代碼。32023/2/3二、語義分析的范圍1.確定類型:確定標識符所關(guān)聯(lián)的數(shù)據(jù)類型。2.類型檢查:按語言的類型規(guī)則,檢查運算的合法性與運算分量類型的一致性,必要時作類型轉(zhuǎn)換。3.識別含義:根據(jù)語言的語義定義(形式或非形式),識別程序中各構(gòu)造成分組合到一起的含義,并作相應(yīng)的語義處理(生成中間代碼或目標代碼)42023/2/34.控制流檢查:控制流語句必須轉(zhuǎn)移到合法的地方。如:C中,break語句規(guī)定跳出最內(nèi)層的循環(huán)或switch語句.5.一致性檢查:在很多場合要求對象只能被說明一次(避免重復(fù)定義)。6.相關(guān)名字檢查:如:Ada,循環(huán)或塊可以有一個名字,它出現(xiàn)在這些結(jié)構(gòu)的開頭或結(jié)尾。編譯程序必須檢查這兩個地方用的名字是否相同。52023/2/3三、語義描述工具和語義分析方法語義描述工具目前流行:用屬性文法作為描述語義的工具。語義分析方法 根據(jù)描述屬性文法的語義規(guī)則的方式不同,語義分析方法分為:語法制導(dǎo)定義方法翻譯方案62023/2/31中間語言中間語言:它介于源程序到目標語言程序中間程序的語言中間語言程序:用中間語言表示的程序。作用:用于編譯程序,將源程序翻譯成等價的中間語言程序,再將中間語言程序轉(zhuǎn)化成目標程序(即將語義分析和目標代碼生成分開處理)源程序 中間語言程序 目標程序中間語言是表示語法制導(dǎo)翻譯的結(jié)果。等價變換轉(zhuǎn)化7.1中間語言72023/2/3好處:中間語言與機器無關(guān),使采用中間語言進行翻譯的編譯程序系統(tǒng)易于移植。易于優(yōu)化翻譯后的代碼。使編譯程序的結(jié)構(gòu)在邏輯上更簡單明確。2中間語言的表示常見:逆波蘭表示 四元式表示和三地址代碼、三元式 圖表示:DAG和樹形表示82023/2/37.1.1逆波蘭表示由波蘭邏輯學家J.Lukasiewicz(盧卡西維茲)首先提出用來表示表達式的方法,后來推廣到表示程序設(shè)計語言中的其它語法成分。表達式的逆波蘭表示表達式的表示:中綴表示: 運算符居中,運算對象在左右兩邊:a+b波蘭表示:前綴表示:運算符在前,運算對象在后:+ab后綴表示:運算對象在前,運算符在后:ab+…(逆波蘭表示)92023/2/3例:逆波蘭表示的例子102023/2/3(1)表達式逆波蘭表示的定義:設(shè)E是一般表達式,則:
一般表達式
逆波蘭表達式若E為變量或常量 E(E) E的逆波蘭式E(1)opE(2)(二目運算) E(1)的逆波蘭式E(2)的逆波蘭式opopE(單目運算) E的逆波蘭式op112023/2/3把表達式翻譯成后綴式的語義規(guī)則描述產(chǎn)生式E→E(1)opE(2)E→(E(1))E→id
語義動作E.code:=E(1).code||E(2).code||opE.code:=E(1).codeE.code:=idE.code表示E后綴形式op表示任意二元操作符“||”表示后綴形式的連接。122023/2/3(2)逆波蘭表示的特點a.標識符(運算對象)出現(xiàn)的順序(從左到右)和原有順序相同。b.運算符是按實際計算順序(從左到右)出現(xiàn)的。c.運算符緊跟在運算對象的后面出現(xiàn),并且沒有括號。132023/2/3(3)好處:易于對表達式的計算處理對于一般表達式的計算,系統(tǒng)需要用兩個工作棧分別處理運算對象和運算符。對于逆波蘭表示的表達式計算處理只用一個工作棧。一般的計算過程是:自左至右掃描后綴式,每碰到運算量就把它推進棧。每碰到k目運算符就把它作用于棧頂?shù)膋個項,并用運算結(jié)果代替這k個項。142023/2/3例:逆波蘭式ab+c*的計算處理過程遇運算對象a,b入棧掃描ab+c*棧遇二目運算符+c*取出a,b,運算結(jié)果T入棧取出c,T作運算,設(shè)結(jié)果T1遇運算符*c*遇運算對象c入棧152023/2/32.形成逆波蘭表示 怎樣將一般表達式轉(zhuǎn)換成逆波蘭表示?
基本思想:從左到右掃描表達式,每遇到:
1o
表達式中的運算對象則往左去。
2o
表達式中的運算符,則與運算符棧頂元素比較優(yōu)先數(shù):162023/2/3逆波蘭表示表達式運算對象運算符進棧出棧運算符棧
如果運算符棧頂元素的優(yōu)先數(shù)大于或等于表達式中當前的運算符優(yōu)先數(shù),則棧頂元素退棧向左去。然后當前運算符繼續(xù)與棧頂?shù)男略乇容^優(yōu)先數(shù)。直到棧頂元素的優(yōu)先數(shù)小于表達式中當前運算符為止。此時,才將表達式中當前運算符進棧。172023/2/3例:畫出形成表達式a*(b+c/d)的逆波蘭表示過程a*(b+c/d)##步驟①a(b+c/d)#*#步驟②ab+c/d)#(*#步驟③ab+c/d)#(*#步驟④abc/d)#+(*#步驟⑤abc/d)#+(*#步驟⑥182023/2/3abcd)#/+(*#步驟⑦abcd)#/+(*#步驟⑧/+(*#abcd/)#步驟⑨+(*#abcd/+)#步驟⑩*#abcd/+*#步驟⑾192023/2/3形成逆波蘭表示的過程,實質(zhì)上是表達式的翻譯過程。(算法不難寫出)例:a/b/c+d=>ab/c/d+(a+b)*(c-d/e)=>ab+cde/-*202023/2/3數(shù)組POST存放后綴式:k為下標,初值為1上述語義動作可實現(xiàn)為: 產(chǎn)生式 程序段
E→E(1)opE(2) {POST[k]:=op;k:=k+1} E→(E(1)) {} E→i {POST[k]:=i;k:=k+1}例:輸入串a(chǎn)+b+c的分析和翻譯
POST:12345E→E(1)opE(2) E.code:=E(1).code||E(2).code||opE→(E(1)) E.code:=E(1).codeE→id E.code:=idab+c+…212023/2/37.1.2圖表示法圖表示法DAG抽象語法樹
222023/2/37.1.2圖表示法無循環(huán)有向圖(DirectedAcyclicGraph,簡稱DAG)對表達式中的每個子表達式,DAG中都有一個結(jié)點一個內(nèi)部結(jié)點代表一個操作符,它的孩子代表操作數(shù)在一個DAG中代表公共子表達式的結(jié)點具有多個父結(jié)點232023/2/3a:=b*(-c)+b*(-c)的圖表示法assigna+*buminuscDAGassigna+*buminusc抽象語法樹*buminusc242023/2/3抽象語法樹對應(yīng)的代碼:
T1:=-c T2:=b*T1
T3:=-c T4:=b*T3 T5:=T2+T4
a:=T5assigna+*buminusc抽象語法樹*buminusc252023/2/3DAG對應(yīng)的代碼:T1:=-cT2:=b*T1T5:=T2+T2a:=T5assigna+*buminuscDAG抽象語法樹對應(yīng)的代碼:
T1:=-c T2:=b*T1
T3:=-c T4:=b*T3 T5:=T2+T4
a:=T5262023/2/3
產(chǎn)生賦值語句抽象語法樹的屬性文法
產(chǎn)生式 語義規(guī)則S→id:=E S.nptr:=mknode(‘a(chǎn)ssign’,
mkleaf(id,id.place),E.nptr)E→E1+E2
E.nptr:=mknode(‘+’,E1.nptr,E2.nptr)E→E1*E2
E.nptr:=mknode(‘*’,E1.nptr,E2.nptr)E→-E1
E.nptr:=mknode(‘uminus’,E1.nptr)E→(E1) E.nptr:=E1.nptrE→id E.nptr:=mkleaf(id,id.place)272023/2/37.1.3三地址代碼三地址代碼x:=yopz三地址代碼可以看成是抽象語法樹或DAG的一種線性表示282023/2/3a:=b*(-c)+b*(-c)的圖表示法assigna+*buminuscDAGassigna+*buminusc抽象語法樹*buminusc292023/2/3 T1:=-c T1:=-c T2:=b*T1 T2:=b*T1 T3:=-c T5:=T2+T2 T4:=b*T3 a:=T5 T5:=T2+T4
a:=T5對于抽象語法樹的代碼 對于DAG的代碼302023/2/3三地址語句的種類x:=yopzx:=opyx:=ygotoLifxrelopygotoL或ifagotoLparamx和callp,n,以及返回語句returnyx:=y[i]及x[i]:=y的索引賦值x:=&y,x:=*y和*x:=y的地址和指針賦值312023/2/3生成三地址代碼時,臨時變量的名字對應(yīng)抽象語法樹的內(nèi)部結(jié)點id:=E對表達式E求值并置于變量T中值id.place:=T322023/2/3從賦值語句生成三地址代碼的S-屬性文法非終結(jié)符號S有綜合屬性S.code,它代表賦值語句S的三地址代碼。非終結(jié)符號E有如下兩個屬性:E.place表示存放E值的名字。E.code表示對E求值的三地址語句序列。函數(shù)newtemp的功能是,每次調(diào)用它時,將返回一個不同臨時變量名字,如T1,T2,…。gen(x‘:=’y‘+’z)表示生成三地址代碼。332023/2/3為賦值語句生成三地址代碼的S-屬性文法定義
產(chǎn)生式 語義規(guī)則S→id:=E S.code:=E.code||gen(id.place‘:=’E.place)E→E1+E2 E.place:=newtemp; E.code:=E1.code||E2.code|| gen(E.place‘:=’E1.place‘+’E2.place)E→E1*E2 E.place:=newtemp; E.code:=E1.code||E2.code|| gen(E.place‘:=’E1.place‘*’E2.place)E→-E1 E.place:=newtemp; E.code:=E1.code|| gen(E.place‘:=’‘uminus’E1.place)E→(E1) E.place:=E1.place; E.code:=E1.codeE→id E.place:=id.place; E.code=‘’342023/2/3三地址語句四元式一個帶有四個域的記錄結(jié)構(gòu),這四個域分別稱為op,arg1,arg2及result op arg1 arg2 result(0) uminus c T1(1) * b T1 T2(2) uminus c T3(3) * b T3 T4(4) + T2 T4 T5(5) := T5 a
352023/2/3三地址語句三元式通過計算臨時變
溫馨提示
- 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)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《腎移植術(shù)后的護理》課件
- 養(yǎng)老院老人生活設(shè)施維修人員激勵制度
- 養(yǎng)老院老人關(guān)愛服務(wù)規(guī)范制度
- 《用餐的經(jīng)驗過程》課件
- 2024年泥工裝修項目合作合同樣本版B版
- 施工成本控制的合同(2篇)
- 健美操基本步伐課件
- 2024年甲乙雙方關(guān)于城市軌道交通信號系統(tǒng)建設(shè)與維護合同
- 刑法學課程課件教案緒論
- 2025年廊坊貨運從業(yè)資格模擬考
- GB/T 4678.2-2017壓鑄模零件第2部分:圓形鑲塊
- 美國十條誡令
- 過敏性紫癜-教學課件
- GB/T 1931-2009木材含水率測定方法
- 神態(tài)描寫課件
- 商業(yè)經(jīng)營管理有限公司組織架構(gòu)、崗位設(shè)置與管理職能
- 2022年讀者出版集團有限公司招聘筆試試題及答案解析
- NB∕T 33009-2021 電動汽車充換電設(shè)施建設(shè)技術(shù)導(dǎo)則
- 大學《傳播學概論》試卷及答案
- 住院醫(yī)師兒外科Ⅰ階段:小兒心胸外科考試題庫
- 管理會計論文范文大全(推薦十篇)
評論
0/150
提交評論