




已閱讀5頁(yè),還剩4頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
PL/0 語(yǔ)言編譯器分析實(shí)驗(yàn)報(bào)告學(xué)院:計(jì)算機(jī)學(xué)院學(xué)號(hào):1112057195姓名:夏建鑫課程名稱:編譯原理一、實(shí)驗(yàn)?zāi)康?通過(guò)閱讀與解析一個(gè)實(shí)際編譯器(PL/0語(yǔ)言編譯器)的源代碼, 加深對(duì)編譯階段(包括詞法分析、語(yǔ)法分析、語(yǔ)義分析、中間代 碼生成等)和編譯系統(tǒng)軟件結(jié)構(gòu)的理解,并達(dá)到提高學(xué)生學(xué)習(xí)興趣的目的。 二、實(shí)驗(yàn)要求 (1)要求掌握基本的程序設(shè)計(jì)技巧(C語(yǔ)言)和閱讀較大規(guī)模程序 源代碼的能力; (2)理解并掌握編譯過(guò)程的邏輯階段及各邏輯階段的功能; (3)要求能把握整個(gè)系統(tǒng)(PL/0語(yǔ)言編譯器)的體系結(jié)構(gòu),各功能 模塊的功能,各模塊之間的接口; (4)要求能總結(jié)出實(shí)現(xiàn)編譯過(guò)程各邏輯階段功能采用的具體算法與技術(shù)。 三、實(shí)驗(yàn)步驟 (1) 根據(jù)PL/0語(yǔ)言的語(yǔ)法圖,理解PL/0語(yǔ)言各級(jí)語(yǔ)法單位的結(jié)構(gòu),掌握PL/0語(yǔ)言合法程序的結(jié)構(gòu); (2)從總體上分析整個(gè)系統(tǒng)的體系結(jié)構(gòu)、各功能模塊的功能、各模塊之間的調(diào)用關(guān)系、各模塊之間的接口; (3)詳細(xì)分析各子程序和函數(shù)的代碼結(jié)構(gòu)、程序流程、采用的主要算法及實(shí)現(xiàn)的功能; (4)撰寫(xiě)分析報(bào)告,主要內(nèi)容包括系統(tǒng)結(jié)構(gòu)框圖、模塊接口、主要算法、各模塊程序流程圖等。四、報(bào)告內(nèi)容 PL/0 語(yǔ)言語(yǔ)法的 BNF 表示-1,對(duì)語(yǔ)法描述圖的解析 . 變量說(shuō)明部分 const ,; = var ,; | ; procedure ; | := begin end ; | odd +|- |() +|- *|/ =|= if then call while do a|b|.|x|y|z 0|1|2|.|8|9編譯程序總體流程圖 Pl/0詞法分析程序Getsym識(shí)別的單詞: (類別,值) 保留字:如:BEGIN、 END、 IF、 THEN等 運(yùn)算符: 如:+、-、*、/、:=、#、=、=等 標(biāo)識(shí)符: 用戶定義的變量名、常數(shù)名、過(guò)程名 常數(shù): 如:10、25、100等整數(shù) 界符: 如:,、. 、; 、( 、)等 讀字符子程序(getch) 表達(dá)式的遞歸子程序?qū)崿F(xiàn) procedure expr; begin if sym in plus, minus then begin getsym; term; end else term; while sym in plus, minus do begin getsym; term; end end;因子=標(biāo)識(shí)符|無(wú)符號(hào)整數(shù)|(表達(dá)式) 因子的遞歸子程序?qū)崿F(xiàn)procedure factor;begin if sym ident then begin if sym number then begin if sym = ( then begin getsym; expr; if sym = ) then getsym else error end else error end else getsym end else getsym end; 常量定義語(yǔ)句的處理語(yǔ)法:: := const , ;: := =: := if sym = constsym then begin getsym; (* 獲取下一個(gè)token,正常應(yīng)為用作常量名的標(biāo)識(shí)符 *) repeat (* 反復(fù)進(jìn)行常量聲明 *) constdeclaration; (* 聲明以當(dāng)前token為標(biāo)識(shí)符的常量 *) while sym = comma do (* 如果遇到了逗號(hào)則反復(fù)聲明下一常量*) begin getsym; (* 獲取下一個(gè)token,這里正好應(yīng)該是標(biāo)識(shí)符 *) constdeclaration (* 聲明以當(dāng)前token為標(biāo)識(shí)符的常量 *) end; if sym = semicolon then (* 如果常量聲明結(jié)束,應(yīng)遇到分號(hào) *) getsym (* 獲取下一個(gè)token,為下一輪循環(huán)做好準(zhǔn)備 *) else error(5) (*提示5號(hào)錯(cuò)誤 *) until sym ident (* 如果遇到非標(biāo)識(shí)符,則常量聲明結(jié)束 *) end; 常量說(shuō)明處理 procedure constdeclaration; begin if sym = ident then begin getsym; if sym in eql, becomes then (* 如果是等號(hào)或賦值號(hào) *) if sym = becomes then (* 如果是賦值號(hào)(常量生明中應(yīng)該是等號(hào)) *) error(1); (* 提示1號(hào)錯(cuò)誤 *) getsym; (* 獲取下一個(gè)token,等號(hào)或賦值號(hào)后應(yīng)接上數(shù)字 *) if sym = number then (* 如果的確是數(shù)字 *) begin enter(constant); (* 把這個(gè)常量登陸到符號(hào)表 *) getsym (* 獲取下一個(gè)token,為后面作準(zhǔn)備 *) end else error(2) (* 如果等號(hào)后接的不是數(shù)字,提示2號(hào)錯(cuò)誤 *) else error(3)(* 如常量標(biāo)識(shí)符后不是等號(hào)或賦值號(hào),提示3號(hào)錯(cuò)誤 *) end else error(4) end(* constdeclaration *);變量定義語(yǔ)句的處理語(yǔ)法:: := var , ; if sym=varsym then begin getsym; repeat vardeclaration;(*變量說(shuō)明處理*) while sym=comma do begin getsym; vardeclaration end; if sym=semicolon then getsym else error(5) until symident; end;變量說(shuō)明處理procedure ardeclaration; begin if sym=ident then begin enter(variable); getsym end else error(4) end(*vardeclaration*);過(guò)程定義語(yǔ)句的處理程序: while sym = procsym do (* 循環(huán)聲明各子過(guò)程 *) begin getsym; (* 獲取下一個(gè)token,此處正常應(yīng)為作為過(guò)程名的標(biāo)識(shí)符 *) if sym = ident then (* 如果token確為標(biāo)識(shí)符 *) begin enter(procedur); (* 把這個(gè)過(guò)程登錄到名字表中 *) getsym (* 獲取下一個(gè)token,正常情況應(yīng)為分號(hào) *) end else error(4); (* 否則提示4號(hào)錯(cuò)誤 *) if sym = semicolon then (* 如果當(dāng)前token為分號(hào) *) getsym (* 獲取下一個(gè)token,準(zhǔn)備進(jìn)行語(yǔ)法分析的遞歸調(diào)用 *) else error(5); (* 否則提示5號(hào)錯(cuò)誤 *) 解釋執(zhí)行的流程圖interpret三個(gè)寄存器賦初值 t:=0;b:=1;p:=0;主程序的SL,DL,RA賦初值s1:=0; s2=0; s3=0;i:=codep;p:=p+1;執(zhí)行指令iP=0?返回PL/0源程序的擴(kuò)充擴(kuò)充FOR TO和FOR DOWNTO語(yǔ)句,此功能的關(guān)鍵是如何判斷條件是否成立,并如何進(jìn)行程序跳轉(zhuǎn).在這里用到了幾條指令,和地址回填技術(shù).擴(kuò)充程序如下: case FORSYM: GetSym(); if(SYM!=IDENT)Error(31); /FOR后面要標(biāo)識(shí)符 i=POSITION(ID,TX);if (i=0) Error(11);else if (TABLEi.KIND!=VARIABLE) /*ASSIGNMENT TO NON-VARIABLE*/ Error(12); /變量 GetSym(); if(SYM!=BECOMES) Error(13); GetSym(); EXPRESSION(SymSetUnion(SymSetNew(TOSYM,DOWNTOSYM,DOSYM),FSYS),LEV,TX);/表達(dá)式 if(SYM=DOWNTOSYM) CX1=CX; GetSym(); GEN(STO,LEV-TABLEi.vp.LEVEL,TABLEi.vp.ADR);/保存結(jié)果至變量單元 GEN(LOD,LEV-TABLEi.vp.LEVEL,TABLEi.vp.ADR);/重新調(diào)入棧頂 EXPRESSION(SymSetAdd(DOSYM,FSYS),LEV,TX);/表達(dá)式 GEN(OPR,0,11);/判斷運(yùn)算 CX2=CX; GEN(JPC,0,0);/如果棧頂非真跳轉(zhuǎn) GEN(LOD,LEV-TABLEi.vp.LEVEL,TABLEi.vp.ADR);/重新調(diào)入棧頂 GEN(LIT,0,1) ;/送1到棧頂 GEN(OPR,0,3); /減運(yùn)算 if(SYM=DOSYM) GetSym(); STATEMENT(FSYS,LEV,TX); GEN(JMP,0,CX1); CODECX2.A=CX; else if(SYM=TOSYM) CX1=CX;GetSym(); GEN(STO,LEV-TABLEi.vp.LEVEL,TABLEi.vp.ADR); /保存結(jié)果至變量單元 GEN(LOD,LEV-TABLEi.vp.LEVEL,TABLEi.vp.ADR); /重新調(diào)入棧頂 EXPRESSION(SymSetAdd(DOSYM,FSYS),LEV,TX);/表達(dá)式分析 GEN(OPR,0,13);/判斷運(yùn)算 CX
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 高考學(xué)考試題及答案
- 工程材料考試題及答案
- 調(diào)車員安全管理制度
- 貨運(yùn)車公司管理制度
- 車間輔助區(qū)管理制度
- 2025至2030年中國(guó)折疊式郵政集裝箱行業(yè)投資前景及策略咨詢報(bào)告
- 運(yùn)營(yíng)部流程管理制度
- 近效期試劑管理制度
- 進(jìn)出庫(kù)物資管理制度
- 違反作業(yè)票管理制度
- 糖尿病周圍血管病變課件
- 新時(shí)代中國(guó)特色社會(huì)主義理論與實(shí)踐(2021版)課后思考題答案
- 骨痿臨床路徑及表單
- 2023年江蘇省蘇州大學(xué)醫(yī)學(xué)部藥學(xué)院統(tǒng)招博士后招收(共500題含答案解析)高頻考點(diǎn)題庫(kù)參考模擬練習(xí)試卷
- 上海市閔行區(qū)2022-2023學(xué)年高一下學(xué)期期末數(shù)學(xué)試題(無(wú)答案)
- 2023年全國(guó)高考語(yǔ)文乙卷作文“一花獨(dú)放不是春百花齊放春滿園”寫(xiě)作
- 合作方案介紹文案
- 年部級(jí)優(yōu)課馬克思主義在中國(guó)的傳播
- 北京市智慧社區(qū)建設(shè)指導(dǎo)標(biāo)準(zhǔn)
- 檢驗(yàn)科生物安全防護(hù)知識(shí)培訓(xùn)試題及
- 2023年全國(guó)高考體育單招英語(yǔ)高頻考點(diǎn)歸納總結(jié)(復(fù)習(xí)必背)
評(píng)論
0/150
提交評(píng)論