版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、Chapter 5.5 布爾表達(dá)式的翻譯1. 概述2. 布爾表達(dá)式的語義及作用n布爾表達(dá)式的語義在于指明計(jì)算一個(gè)邏輯值的規(guī)那么布爾表達(dá)式的語義在于指明計(jì)算一個(gè)邏輯值的規(guī)那么 .n布爾表達(dá)式在程序設(shè)計(jì)言語中有兩個(gè)根本的作用:布爾表達(dá)式在程序設(shè)計(jì)言語中有兩個(gè)根本的作用:n一是在某些控制語句中作為實(shí)現(xiàn)控制轉(zhuǎn)移的條件;一是在某些控制語句中作為實(shí)現(xiàn)控制轉(zhuǎn)移的條件;n另一個(gè)那么是用于計(jì)算邏輯值本身。另一個(gè)那么是用于計(jì)算邏輯值本身。n商定商定:各類運(yùn)算符的優(yōu)先順序由高至低如下:各類運(yùn)算符的優(yōu)先順序由高至低如下:n括號(hào)括號(hào)n算術(shù)運(yùn)算符算術(shù)運(yùn)算符*、/n +、-n關(guān)系運(yùn)算符關(guān)系運(yùn)算符、=、n邏輯運(yùn)算符邏輯運(yùn)算符
2、n n 3. 布爾表達(dá)式的等價(jià)解釋-求值角度3. 布爾表達(dá)式的等價(jià)解釋-過程角度4. 布爾表達(dá)式的出口5. 控制語句中的布爾表達(dá)式if E then S1 else S2或while E do STE的代碼S1的代碼S2的代碼E的代碼S的代碼TFF6. 布爾表達(dá)式真假值確實(shí)定一個(gè)布爾表達(dá)式E的真假值確實(shí)定,是在語法翻譯過程中,根據(jù)(5.2)-(5.4)等價(jià)解釋式逐漸進(jìn)展的。 例如,對于布爾表達(dá)式E = E(1) E(2)假設(shè)E(1)為真,那么E必為真,故E(1)的真出口必是E的真出口(之一);假設(shè)E(1)為假,那么E的真假值取決于E(2)的真假值,此時(shí),需對E(2)進(jìn)展計(jì)算,由此可見,E(1)
3、的假出口應(yīng)為E(2)對應(yīng)的四元式的序號(hào)(E(2)的入口),同時(shí),E(2)的真、假出口也是E的真、假出口。類似地,可確定E(1) E(2) 、E及更復(fù)雜的表達(dá)式的真、假出口。 7. 條件語句的翻譯結(jié)果在設(shè)計(jì)布爾表達(dá)式翻譯算法即編寫語義動(dòng)作時(shí),可定義和運(yùn)用如下三類四元式:(jnz, A1, ,p)當(dāng)A1為真(非零)時(shí),轉(zhuǎn)向第p四元式;(jrop,A1,A2,p)當(dāng)關(guān)系A(chǔ)1 rop A2 成立時(shí),轉(zhuǎn)向第p四元式;(j, , ,p) 無條件轉(zhuǎn)向第p四元式例如,對于條件語句if ABC then S1 else S2經(jīng)翻譯后,可得四元式序列: (1) (jnz, A, -, 5)(2) (j, - ,-
4、 , 3)(3) (j, B, C, 5)(4) (j, -, -, p+1)(5) S1相應(yīng)的四元式序列(p) (j, -, -, q)(p+1) S2相應(yīng)的四元式序列(q) 其中,表達(dá)式A的真出口為5也是整個(gè)表達(dá)式的真出口,假出口為3即表達(dá)式BC的第一四元式;BC的真、假出口也分別是整個(gè)表達(dá)式的真、假出口。8. 拉鏈與回填在自底向上的語法制導(dǎo)翻譯時(shí)或者說,在S-屬性翻譯文法中), 在產(chǎn)生一個(gè)(無)條件轉(zhuǎn)移四元式時(shí), 它所要轉(zhuǎn)向的那個(gè)四元式有時(shí)髦未產(chǎn)生,故無法立刻產(chǎn)生一個(gè)完全的控制轉(zhuǎn)移四元式。例如,在上例中,在產(chǎn)生第一個(gè)四元式時(shí),由于語句S1的中間代碼尚未產(chǎn)生,即A的真出口確切位置并不知道,
5、故此時(shí)只能產(chǎn)生一個(gè)空缺轉(zhuǎn)移目的的四元式(jnz,A,-,0),并將此四元式的序號(hào)(即1)作為語義信息存起來,待開場翻譯S1時(shí),再將S1的第一四元式的序號(hào)(即5)回填這個(gè)不完全的四元式。另外,在翻譯過程中,經(jīng)常會(huì)出現(xiàn)假設(shè)干轉(zhuǎn)移四元式轉(zhuǎn)向同一目的,但此目的的詳細(xì)位置又尚未確定的情況,此時(shí)我們可將這些四元式用拉鏈的方法將它們鏈接起來,用一指針指向鏈頭,在確定了目的四元式的位置之后,再回填這個(gè)鏈。n對于一個(gè)布爾表達(dá)式E來說,它應(yīng)有兩條鏈:真出口鏈(稱為T鏈,記作TC)和假出口鏈(稱為F鏈,記作FC)。它們就是非終結(jié)符Expr的兩個(gè)屬性Expr.TC及Expr.FC。n例如,對于上述if語句中的布爾式E
6、=AB0時(shí),它給出本鏈的后繼四元式的序號(hào), Result =0時(shí)表示本四元式是鏈尾結(jié)點(diǎn)。(1)(jnz,A,-,0)( 2 )( j , - , - , 3 ) E.TC(3)(j,B,C,1) E.FC (4)(j, -,-,0) 9. 文法的“拆分n為便于實(shí)現(xiàn)布爾表達(dá)式的語法制導(dǎo)翻譯,我們先改寫文法,以便能在翻譯過程中的適當(dāng)時(shí)機(jī)獲得所需的語義屬性值。例如,可將文法(5.1)改寫為:nExprExpr Expr | Expr Expr | Expr|niden |iden Rop iden | ( Expr )nExpr Expr nExpr Expr (5.7)n 將文法進(jìn)展“拆分的目的:
7、n1.在翻譯完運(yùn)算符左側(cè)的表達(dá)式后,可以及時(shí)獲取其語義屬性TC及FCn2.完成用下一四元式序號(hào)即運(yùn)算符右側(cè)表達(dá)式的第一四元式之序號(hào)回填前一表達(dá)式的相應(yīng)真假鏈TCFC,n3.將其另一鏈FCTC作為產(chǎn)生式左部符號(hào)的綜合屬性FCTC傳播之。10. 語義變量及輔助語義函數(shù)1.NXQ全局變量,用于指示所要產(chǎn)生的下一四元式的序號(hào);2.GEN其意義同前,每次調(diào)用,NXQ+;3.int Merge(int p1,int p2)將鏈?zhǔn)住爸羔樂謩e為p1和p2的兩條鏈合并為一條,并前往新鏈的鏈?zhǔn)住爸羔槾颂幍摹爸羔槍?shí)踐上是四元式的序號(hào),應(yīng)為整型值我們假定四元式是以一構(gòu)造方式表示存儲(chǔ)的:struct _Quadrupl
8、e int Op, arg1, arg2, Result; QuadrupleList; 4.void BackPatch(int p,int t)用四元式序號(hào)t回填以p為首的鏈,將鏈中每個(gè)四元式的Result域改寫為t的值。函數(shù)Merge( )及BackPatch( )的程序見書11. 翻譯布爾表達(dá)式的屬性文法1.Expriden $.TC= NXQ; $.FC= NXQ+1;GEN(jnz, Entry($1), 0, 0); GEN(j,0,0,0); | iden rop iden $.TC= NXQ; $.FC= NXQ+1; GEN(jrop, Entry($1), Entry($3), 0); GEN(j, 0, 0, 0); | ( Expr ) $.TC= $2.TC; $.FC= $2.FC; | Expr $.TC= $2.FC; $.FC= $2.TC; | Expr Expr $.TC= $2.TC; $.FC=Merge($1.FC,$2.FC); | Expr Ex
溫馨提示
- 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)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 小鎮(zhèn)店鋪?zhàn)赓U合同范例
- 標(biāo)書項(xiàng)目合同范例
- 相機(jī)租賃電子合同范例
- 花園管家服務(wù)合同范例
- 2024年標(biāo)準(zhǔn)模具鋼材采購合同版B版
- 2024年度生產(chǎn)車間承包與智能制造解決方案合同3篇
- 2024年城市更新項(xiàng)目土地租賃合同范本附帶拆遷安置協(xié)議3篇
- 2024年度國有企事業(yè)單位人力資源部經(jīng)理任用與績效考核合同3篇
- 2024年短期租賃轎車合同協(xié)議2篇
- 2024年版二手鋼結(jié)構(gòu)購銷合同3篇
- 《高等數(shù)學(xué)》課程思政教學(xué)大綱
- 國際疾病分類手術(shù)碼(ICD-9-CM-3)使用手冊
- 物資部對標(biāo)管理實(shí)施方案
- 上海工程技術(shù)大學(xué)《管理信息系統(tǒng)》 ~學(xué)年 第 一 學(xué)期 實(shí)驗(yàn)報(bào)告
- 職工醫(yī)保基數(shù)調(diào)整對比明細(xì)表Excel模板
- 送你一個(gè)字評(píng)語2022
- 放射科優(yōu)質(zhì)護(hù)理服務(wù)PPT學(xué)習(xí)教案
- GB_T 22627-2022水處理劑 聚氯化鋁_(高清-最新版)
- 教學(xué)團(tuán)隊(duì)建設(shè)總結(jié)報(bào)告
- 看守所釋放證明書
- 魚骨圖-PPT模板
評(píng)論
0/150
提交評(píng)論