




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上 編譯系統(tǒng)設(shè)計(jì)實(shí)踐實(shí)驗(yàn)項(xiàng)目三:語(yǔ)法制導(dǎo)翻譯與生成中間代碼學(xué)號(hào): 姓名: 年級(jí): 學(xué)院: 數(shù)計(jì)學(xué)院 專業(yè): 計(jì)算機(jī) 本組其它成員:學(xué)號(hào) 姓名 學(xué)號(hào) 姓名 實(shí)驗(yàn)時(shí)間:20162017學(xué)年第一學(xué)期任課教師: 一、實(shí)驗(yàn)?zāi)康耐ㄟ^語(yǔ)法制導(dǎo)或翻譯模式生成中間代碼。二、實(shí)驗(yàn)內(nèi)容在自底向上語(yǔ)法分析基礎(chǔ)上設(shè)計(jì)語(yǔ)義規(guī)則(語(yǔ)法制導(dǎo)翻譯),將源程序翻譯為四元式輸出,若有錯(cuò)誤將錯(cuò)誤信息輸出。三、設(shè)計(jì)思路1. 分析過程 主函數(shù),讀取文件,存入字符串?dāng)?shù)組,調(diào)用語(yǔ)義分析,判斷關(guān)鍵字,調(diào)用相應(yīng)的語(yǔ)義規(guī)則(這里只有if和while和賦值語(yǔ)句),賦值語(yǔ)句調(diào)用表達(dá)式處理,if語(yǔ)句調(diào)用條件表達(dá)式處理,while
2、也是調(diào)用表達(dá)式處理,然后是一個(gè)遞歸過程,不斷的遞歸調(diào)用,按序輸出三地址語(yǔ)句。在本例程序中選用expr及num作為運(yùn)算數(shù)。 2. 主要函數(shù)string link() /字符串和數(shù)字的連接string element() /獲取表達(dá)式中的元素對(duì)象string expression() /處理表達(dá)式string expression_1() /處理表達(dá)式 string biaodashi() /處理表達(dá)式,轉(zhuǎn)為三地址輸出string biaodashi_1() /遞歸-處理表達(dá)式,轉(zhuǎn)為三地址輸出string getOperator() /判斷并獲取運(yùn)算符void condition(int L1,i
3、nt L2) /輸出if語(yǔ)句的條件的三地址代碼void yuyifenxi_list() /生成并輸出條件返回地址void yuyifenxi_list_1() /遞歸-生成并輸出條件返回地址void yuyifenxi(int next,int &flag) /判斷關(guān)鍵字,調(diào)用相應(yīng)的產(chǎn)生式分析 void readfile() /文件讀入四、測(cè)試報(bào)告1. 第一組測(cè)試: 圖1-1 輸入待翻譯代碼 圖1-2 中間代碼生成2. 第二組測(cè)試: 圖2-1 輸入待翻譯代碼圖2-2 中間代碼生成3.第三組測(cè)試:錯(cuò)誤待翻譯代碼 圖3-1 輸入待翻譯代碼 圖3-2 中間代碼生成五、實(shí)驗(yàn)總結(jié)實(shí)驗(yàn)三的重點(diǎn)在
4、于判斷關(guān)鍵字,調(diào)用相應(yīng)的產(chǎn)生式分析及處理表達(dá)式,轉(zhuǎn)為三地址輸出部分,也是很費(fèi)時(shí)間的難點(diǎn)部分,但通過查閱書本及網(wǎng)上資料,還是將其以多個(gè)處理函數(shù)的遞歸調(diào)用實(shí)現(xiàn)了,雖然最后實(shí)現(xiàn)結(jié)果對(duì)錯(cuò)誤的分析還不夠精確有些差強(qiáng)人意,但畢竟還算有些收獲了。另外,通過三次實(shí)驗(yàn)下來,對(duì)于一個(gè)簡(jiǎn)易編譯器的實(shí)現(xiàn)已經(jīng)有了一個(gè)整體的構(gòu)架了,相信在通過自己以后的深入學(xué)習(xí),一定能寫出屬于自己的編譯器。六、附錄代碼#include <iostream>#include <algorithm>#include<conio.h>using namespace std;int address=100; /
5、每條分析語(yǔ)句的地址 int LID=0; /表示過程執(zhí)行到相應(yīng)位置的地址符號(hào) int tID=0; /用于替換表達(dá)式的標(biāo)識(shí)符 int ip=0;string shuru666;/存放從文件讀入的字符串int maxsize;/設(shè)置存放數(shù)組的長(zhǎng)度 string biaodashi();/*字符串和數(shù)字的連接*/string link(string a,int b)string t=""dot+=b%10+'0'b/=10;while(b);reverse(t.begin(),t.end();return a+t;/*獲取表達(dá)式中的元素對(duì)象*/string el
6、ement()if(shuruip="expr"|shuruip="num")ip+;return shuruip-1;else if(shuruip="(")ip+;string result=biaodashi();if(shuruip=")")ip+;else puts("Lack)");return result;else puts("error");return "" /*處理表達(dá)式*/string expression_1(string &am
7、p;op)if(shuruip="*"|shuruip="/")op=shuruip;ip+;string arg1=element();string op_1="",result=link("t",tID+);string arg2=expression_1(op_1);if(op_1="")op_1="="if(arg2="") cout<<address+<<":"<<" "
8、<<result<<" = "<<arg1<<endl;else cout<<address+<<":"<<" "<<result<<" = "<<arg1<<" "<<op_1<<" "<<arg2<<endl;return result;return "" /*處理表達(dá)式*/
9、string expression()string op="",result=link("t",tID+);string arg1=element();string arg2=expression_1(op);if(op="")op="=" if(arg2="")cout<<address+<<":"<<" "<<result<<" = "<<arg1<<
10、;endl;elsecout<<address+<<":"<<" "<<result<<" = "<<arg1<<" "<<op<<" "<<arg2<<endl;return result; /*遞歸-處理表達(dá)式,轉(zhuǎn)為三地址輸出*/string biaodashi_1(string &op)string result=""if(shur
11、uip="+"|shuruip="-")op=shuruip;ip+;string arg1=expression();string op_1=""string arg2=biaodashi_1(op_1);result=link("t",tID+);if(op_1="")op_1="="if(arg2="")cout<<address+<<":"<<" "<<resu
12、lt<<" = "<<arg1<<endl;elsecout<<address+<<":"<<" "<<result<<" = "<<arg1<<" "<<op_1<<" "<<arg2<<endl;return result; /*處理表達(dá)式,轉(zhuǎn)為三地址輸出*/string biaodashi()string
13、 arg1="",op=""if(shuruip="+"|shuruip="-")arg1=shuruip;ip+;arg1+=expression();string arg2=biaodashi_1(op);string result=link("t",tID+);if(op="")op="="if(arg2="")cout<<address+<<":"<<" &quo
14、t;<<result<<" = "<<arg1<<endl;elsecout<<address+<<":"<<" "<<result<<" = "<<arg1<<" "<<op<<" "<<arg2<<endl;return result;/*判斷并獲取運(yùn)算符*/string getOperator
15、()if(shuruip="="|shuruip="<>"|shuruip="<"|shuruip=">"|shuruip="<="|shuruip=">=")ip+;return shuruip-1;elseputs("error"); return ""/*輸出if語(yǔ)句的條件的三地址代碼*/void condition(int L1,int L2) /L1,L2分別為if條件為true和false
16、時(shí)候的跳轉(zhuǎn)地址 string result=link("t",tID+);string arg1=biaodashi(); /獲得表達(dá)式的運(yùn)算符的左邊內(nèi)容 string op=getOperator(); /獲得表達(dá)式的運(yùn)算符 string arg2=biaodashi(); /獲得表達(dá)式的運(yùn)算符的右邊內(nèi)容 if(arg2="")cout<<" "<<result<<" = "<<arg1<<endl;elsecout<<address+<
17、;<":"<<" "<<result<<" = "<<arg1<<" "<<op<<" "<<arg2<<endl;cout<<address+<<":"<<" if true "<<result<<" goto "<<"L"<
18、<L1<<endl;cout<<address+<<":"<<" if false "<<result<<" goto "<<"L"<<L2<<endl;/*判斷關(guān)鍵字,調(diào)用相應(yīng)的產(chǎn)生式分析*/void yuyifenxi(int next,int &flag) if(shuruip="expr")ip+;if(shuruip="=")/賦值語(yǔ)句 轉(zhuǎn)化為四
19、元式ip+;string arg1=biaodashi();string arg2=""if(arg2 = "") cout<<address+<<":"<<" expr = "<<arg1<<endl;else puts("error");else if(shuruip="if") /if的語(yǔ)義子程序ip+;int L1=LID+;int L2=LID+;if(shuruip="(")ip+;c
20、ondition(L1,L2);elseputs("Lack(");return;if(shuruip=")") ip+;else puts("Lack)");return;printf("L%d:n",L1);yuyifenxi(next,flag);ip+;if(shuruip="else")printf("L%d:n",L2);ip+;yuyifenxi(next,flag);else if(shuruip="while")/while的語(yǔ)義子程序 ip+;int L1=LID+;int L2=LID+;if(shuruip="(")ip+;printf("L%d:n",L1);condition(L2,next);elseputs("Lack(");return;if(shuruip=")") ip+;else puts("Lack)");return;printf("L%d:n",L2);yuyifenxi(nex
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年鏈家房屋買賣定金支付及退還標(biāo)準(zhǔn)協(xié)議
- 二零二五年度住房租賃補(bǔ)貼擔(dān)保服務(wù)合同
- 二零二五年度蘇州市教育機(jī)構(gòu)用工企業(yè)勞動(dòng)合同書
- 二零二五年度云計(jì)算資源合作共享合同
- 2025年度電子商務(wù)平臺(tái)招防范合同法律風(fēng)險(xiǎn)合作協(xié)議
- 2025年度涂料班組涂料行業(yè)市場(chǎng)分析咨詢合同
- 二零二五年度特色日租房短租體驗(yàn)協(xié)議書
- 二零二五年度貸款居間代理及金融科技創(chuàng)新應(yīng)用合同
- 2025年度高端合同事務(wù)律師服務(wù)合同
- 2025年度智慧交通項(xiàng)目提前終止合同及交通設(shè)施移交協(xié)議
- 司機(jī)安全駕駛培訓(xùn)課件
- 硬化性肺泡細(xì)胞瘤-課件
- 簡(jiǎn)明新疆地方史趙陽(yáng)
- 狹窄性腱鞘炎中醫(yī)臨床路徑及表單
- Q∕SY 19001-2017 風(fēng)險(xiǎn)分類分級(jí)規(guī)范
- 智慧消防綜合解決方案
- 市場(chǎng)營(yíng)銷組合策略及營(yíng)銷戰(zhàn)略課件
- 信息技術(shù)基礎(chǔ)ppt課件(完整版)
- DGJ 08-70-2021 建筑物、構(gòu)筑物拆除技術(shù)標(biāo)準(zhǔn)
- 2022年義務(wù)教育語(yǔ)文課程標(biāo)準(zhǔn)(2022版)解讀【新課標(biāo)背景下的初中名著閱讀教學(xué)質(zhì)量提升思考】
- 屋面網(wǎng)架結(jié)構(gòu)液壓提升施工方案(50頁(yè))
評(píng)論
0/150
提交評(píng)論