




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、 工程第一神刀公子編譯原理實(shí)驗(yàn)實(shí)驗(yàn)名稱:中間代碼生成程序設(shè)計(jì)指導(dǎo)老師: 輕語 專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù) 班 級: LOL 學(xué) 號: 0000001 姓 名: 神刀公子 2008.6.22實(shí)驗(yàn)任務(wù):在實(shí)驗(yàn)4的基礎(chǔ)上,完成以下描述賦值語句和算數(shù)表達(dá)式文法GA的語法制導(dǎo)生成中間代碼四元式的過程。 A-V:=E V- EE+T|E-T|T TT*F|T/F|F F(E)|說明:標(biāo)識(shí)符的定義參見實(shí)驗(yàn)一程序的功能描述從文件中讀入表達(dá)式,輸出其四元式的結(jié)果序列 本程序只能生成賦值語句及算數(shù)表達(dá)式中間代碼的四元式不能生成邏輯表達(dá)式及其他復(fù)雜語句中間代碼的四元式,其功能還需要進(jìn)一步完善。程序結(jié)構(gòu)描述打開文件成
2、功N調(diào)用scan()函數(shù)從文件讀入表達(dá)式 Y結(jié)束輸出所讀入的表達(dá)式調(diào)用生成四元式函數(shù)siyuanshi()表達(dá)式中是否有括號N處理括號內(nèi)的 Y處理乘除加減和賦值運(yùn)算sum=0N輸出錯(cuò)誤提示輸出成功 Y結(jié)束程序測試方案測試用例一:d=a+b*(3*n)/(b-a) 測試用例二: x=x*(x+y-(x-y)/(z+x)-y)實(shí)驗(yàn)總結(jié)此程序基本達(dá)到了實(shí)驗(yàn)要求,能夠生成簡單的賦值及算數(shù)表達(dá)式中間代碼的四元式,但其功能實(shí)在是過于簡單。第一次調(diào)試通過后程序還存在以下不足:(1) 此程序只能從文件中讀入一個(gè)表達(dá)式,讀入多個(gè)則會(huì)出錯(cuò);(2) 所讀入的表達(dá)式中若含有多于一個(gè)括號,程序會(huì)出錯(cuò);(3) 括號內(nèi)若多
3、于一個(gè)表達(dá)式則會(huì)出錯(cuò);(4) 在測試用例二中的分析過程明顯是錯(cuò)誤的,這足以看出程序的漏洞很多但經(jīng)過進(jìn)一步優(yōu)化算法,以上問題基本解決,但程序中仍然存在很多不足,例如時(shí)間效率和空間效率方面做的還不夠好,要改善這些不足還需要進(jìn)一步完善程序,在以后的學(xué)習(xí)生活中我會(huì)根據(jù)所學(xué)知識(shí)的不斷深入而不斷完善此程序,爭取使其功能更加強(qiáng)大。經(jīng)過這次實(shí)驗(yàn)我更加深刻的理解了生成中間代碼的算法思想,及時(shí)的將所學(xué)知識(shí)用于實(shí)踐,更加深刻的掌握了所學(xué)知識(shí)。附錄#include#include#includeusing namespace std;#define MAX 100int m=0,sum=0;/sum用于計(jì)算運(yùn)算符的個(gè)
4、數(shù) /m用于標(biāo)記輸入表達(dá)式中字符的個(gè)數(shù) char JG=A;char strMAX;/用于存輸入表達(dá)式int token=0;/左括號的標(biāo)志/*用于更改計(jì)算后數(shù)組中的值*/void change(int e)int f=e+2;char ch=strf;if(ch=A&ch=Z)for(int l=0;l=A&stre=Z)for(int i=0;im;i+)if(stri=stre)stri=JG;void chengchuchuli(int i,int m) i+;for( ;i=m-1;i+)/處理乘除運(yùn)算 if(stri=*|stri=/) cout(stri stri-1 stri+
5、1 JG)endl; change(i-1); stri-1=stri=stri+1=JG; sum-; JG=(char)(int)JG+; void jiajianchuli(int j,int m)j+;for( ;j=m-1;j+)/處理加減運(yùn)算 if(strj=+|strj=-) cout(strj strj-1 strj+1 JG)endl; change(j-1); strj-1=strj=strj+1=JG; sum-; JG=(char)(int)JG+; /*掃描一遍從文件中讀入表達(dá)式*/void scan(FILE *fin) int pMAX; char ch=a;in
6、t c=-1,q=0;while(ch!=EOF)ch=getc(fin);while(ch= |ch=n|ch=t) ch=getc(fin);/消除空格和換行符strm+=ch;if(ch=|ch=+|ch=-|ch=*|ch=/) sum+;else if(ch=() p+c=m-1; else if(ch=) q=m-1; chengchuchuli(pc,q);/從左括號處理到又括號 jiajianchuli(pc,q); JG=(char)(int)JG-; strpc=strm-1=JG; c-; JG=(char)(int)JG+; /*對表達(dá)是進(jìn)行處理并輸出部分四元式*/vo
7、id siyuanshi()for(int i=0;i=m-1;i+)/處理乘除運(yùn)算 if(stri=*|stri=/) cout(stri stri-1 stri+1 JG)endl; change(i-1); stri-1=stri=stri+1=JG; sum-; JG=(char)(int)JG+; for(int j=0;j=m-1;j+)/處理加減運(yùn)算 if(strj=+|strj=-) cout(strj strj-1 strj+1 JG)endl; change(j-1); strj-1=strj=strj+1=JG; sum-; JG=(char)(int)JG+; for(int k=0;k=m-1;k+)/處理賦值運(yùn)算 if(strk=) JG=(char)(int)-JG; cout(strk strk+1 strk-1)endl; sum-; change(k+1); strk-1=JG; /*主函數(shù)*/void main()char inMAX; /用于接收輸入輸出文件名 FILE *fin; /用于指向輸入輸出文件的指針 coutin;coutendl; if (fin=fopen(in,r)=NULL) /判斷輸入文件名是否正確 coutendl打開詞法分析輸入文件出錯(cuò)!endl; cout四元式如下:
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 油庫消防知識(shí)解讀
- 聚乙烯醇海綿行業(yè)分析:高吸水性PVA海綿是最大的細(xì)分市場占51%的份額
- 2025年機(jī)器人產(chǎn)業(yè)人才發(fā)展報(bào)告-智聯(lián)研究院
- 生存秘籍:野外探險(xiǎn)必修課
- 2025年互聯(lián)網(wǎng)醫(yī)療平臺(tái)在線問診服務(wù)質(zhì)量與患者就醫(yī)體驗(yàn)優(yōu)化報(bào)告
- 智慧交通系統(tǒng)中的交通流量預(yù)測技術(shù)2025年應(yīng)用創(chuàng)新報(bào)告
- 2025年公眾參與對環(huán)境影響評價(jià)工作流程的影響分析報(bào)告
- 即時(shí)配送行業(yè)配送路徑優(yōu)化與成本控制:冷鏈物流解決方案報(bào)告
- 工業(yè)互聯(lián)網(wǎng)平臺(tái)IPv6技術(shù)升級在2025年工業(yè)互聯(lián)網(wǎng)平臺(tái)市場拓展與競爭挑戰(zhàn)報(bào)告
- 企業(yè)可持續(xù)發(fā)展目標(biāo)(SDGs)在綠色能源與新能源開發(fā)中的應(yīng)用報(bào)告
- 2025年廣西公需科目答案03
- 2025年人教版七年級下冊生物期末檢測試卷及答案
- 自然辯證法論述題146題帶答案(可打印版)
- 2024年貴州省貴陽市中考生物試題(含答案逐題解析)
- 廉潔應(yīng)征承諾書
- 醫(yī)院培訓(xùn)課件:《發(fā)熱伴血小板減少綜合征醫(yī)院感染防控》
- 積雪草提取物對胃粘膜的保護(hù)作用及其機(jī)制探討
- STEP7下冗余IO編程
- 道教全真禮斗清科儀
- 餐廳小票打印模板72790
- 220kV升壓站電氣設(shè)備調(diào)試方案.
評論
0/150
提交評論