版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、 編譯原理實(shí)驗(yàn)報(bào)告 編譯原理實(shí)驗(yàn)報(bào)告 pl0 編譯原理實(shí)驗(yàn)報(bào)告 pl0 PL/0 語(yǔ)言編譯器分析實(shí)驗(yàn)報(bào)告 學(xué)院: ?計(jì)算機(jī)學(xué)院 學(xué)號(hào): ?1112057195 姓名: ?夏建鑫 課程名稱:編譯原理 一、實(shí)驗(yàn)?zāi)康?通過閱讀與解析一個(gè)實(shí)際編譯器(PL/0 語(yǔ)言編譯器)的源代碼, 加深對(duì)編譯階段(包括詞法分析、語(yǔ)法分析、語(yǔ)義分析、中間代 碼生成等)和編譯系統(tǒng)軟件結(jié)構(gòu)的理解,并達(dá)到提高學(xué)生學(xué)習(xí)興趣的目的。 ? 二、實(shí)驗(yàn)要求 (1)要求掌握
2、基本的程序設(shè)計(jì)技巧(C 語(yǔ)言)和閱讀較大規(guī)模程序 源代碼的能力; (2)理解并掌握編譯過程的邏輯階段及各邏輯階段的功能;(3)要求能把握整個(gè)系統(tǒng) (PL/0 語(yǔ)言編譯器)的體系結(jié)構(gòu),各功能 模塊的功能,各模塊之間的接口; (4)要求能總結(jié)出實(shí)現(xiàn)編譯過程各邏輯階段功能采用的具體算法與技術(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)從總體
3、上分析整個(gè)系統(tǒng)的體系結(jié)構(gòu)、 各功能模塊的功能、 各模塊之間的調(diào)用關(guān)系、各模塊之間的接口; (3)詳細(xì)分析各子程序和函數(shù)的代碼結(jié)構(gòu)、程序流程、采用的主要算法及實(shí)現(xiàn)的功能; (4)撰寫分析報(bào)告,主要內(nèi)容包括系統(tǒng)結(jié)構(gòu)框圖、模塊接口、主要算法、各模塊程序流程圖等。 ? 四、 報(bào)告內(nèi)容 PL/0 語(yǔ)言語(yǔ)法的 BNF 表示-1, 對(duì)語(yǔ)法描述圖的解析 → . → [][變量說(shuō)明部分>][] → const {,}; → = → {} → v
4、ar {,}; → {|} → {;}; → procedure ; → |||| → := → begin end → {;} → | odd → 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ù)字 *) be
5、gin 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ǔ)法:
6、?: := 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ō) 明 處 理 proce
7、dure ardeclaration; begin if sym=ident then begin enter(variable); getsym end else error(4) end(*vardeclaration*); 過程定義語(yǔ)句的處理程序: ? while sym = procsym do (* 循環(huán)聲明各子過程 *) begin getsym; (* 獲取下一個(gè) token,此處正常應(yīng)為作為過程名的標(biāo)識(shí)符 *) if s
8、ym = ident then (* 如果 token 確為標(biāo)識(shí)符 *) begin enter(procedur); (* 把這個(gè)過程登錄到名字表中 *) 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ǔ)
溫馨提示
- 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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 編譯原理pl0課程設(shè)計(jì)報(bào)告
- 編譯原理課程設(shè)計(jì)報(bào)告--pl0編譯器的擴(kuò)充
- 編譯原理課程設(shè)計(jì)報(bào)告---pl0編譯程序改進(jìn)及完善
- 編譯原理課程設(shè)計(jì)-- pl0語(yǔ)言的擴(kuò)充
- 編譯原理課程設(shè)計(jì)---pl0編輯器擴(kuò)充
- 編譯原理實(shí)驗(yàn)報(bào)告
- pl0擴(kuò)展編譯器_設(shè)計(jì)文檔
- 編譯原理課程設(shè)計(jì)--對(duì)pl0進(jìn)行擴(kuò)充和修改
- 編譯原理課程設(shè)計(jì)--對(duì)pl0進(jìn)行擴(kuò)充和修改
- 編譯原理課程設(shè)計(jì)--對(duì)PL0進(jìn)行擴(kuò)充和修改.doc
- 編譯原理實(shí)驗(yàn)報(bào)告.doc
- 編譯原理實(shí)驗(yàn)報(bào)告.doc
- 第二章pl0編譯程序-
- 編譯原理-詞法分析實(shí)驗(yàn)報(bào)告
- 編譯原理實(shí)驗(yàn)報(bào)告-詞法分析
- 編譯原理語(yǔ)法分析實(shí)驗(yàn)報(bào)告
- nfa轉(zhuǎn)化為dfa編譯原理實(shí)驗(yàn)報(bào)告
- 北京印刷學(xué)院編譯原理課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- 數(shù)學(xué)與計(jì)算機(jī)學(xué)院 編譯原理 實(shí)驗(yàn)報(bào)告
- 課程設(shè)計(jì)---pl0功能擴(kuò)充
評(píng)論
0/150
提交評(píng)論