



下載本文檔
版權(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)3 遞歸下降法的語(yǔ)法分析器一、實(shí)驗(yàn)?zāi)康膶W(xué)習(xí)語(yǔ)法分析器的構(gòu)造原理,掌握遞歸下降法的編程方法。二、實(shí)驗(yàn)內(nèi)容用遞歸下降法編寫一個(gè)語(yǔ)法分析程序,使之與詞法分析器結(jié)合,能夠根據(jù)語(yǔ)言的上下文無(wú)關(guān)文法,識(shí)別輸入的單詞序列是否文法的句子。(注意,需要改寫文法,消除左遞歸等)program blockblock stmts stmts stmt stmts | e stmt id = expr ; |if ( bool ) stmt|if ( bool) stmt else stmt|while (bool) stmt |do stmt while (bool ) ; |break ; |blockbool
2、 expr < expr | expr <= expr | expr > expr | expr >= expr | exprexpr expr + term | expr - term | termterm term * factor | term / factor | factorfactor ( expr ) | id | num三、實(shí)驗(yàn)要求個(gè)人完成,提交實(shí)驗(yàn)報(bào)告。實(shí)驗(yàn)報(bào)告中給出采用測(cè)試源代碼片斷,及其對(duì)應(yīng)的最左推導(dǎo)過(guò)程(形式可以自行考慮)。例如,程序片斷i = 2;while (i <=100)sum = sum + i;i = i + 2; 對(duì)應(yīng)的推導(dǎo)過(guò)
3、程為:program Þ blockÞ stmts Þ stmt stmts Þ id = expr ; stmts Þ id = num; stmts Þ id = num; stmt stmts Þ id = num; while (bool) stmt stmts Þ id = num; while (expr<= expr) stmt stmts Þ id = num; while (id <= expr) stmt stmts Þ id = num; while (id &
4、lt;= num) stmt stmts Þ id = num; while (id <= num) block stmts Þ id = num; while (id <= num) stmts stmts Þ四、實(shí)驗(yàn)步驟1、構(gòu)造詞法分析器這個(gè)部分主要是在第二個(gè)實(shí)驗(yàn)的基礎(chǔ)上做一定的修改。首先定義一個(gè)頭文件“”,內(nèi)容為各個(gè)終結(jié)符的數(shù)值代號(hào)。然后使用實(shí)驗(yàn)二中的創(chuàng)建的“*.l”文件,把其中對(duì)終結(jié)符的處理由print語(yǔ)句改為return語(yǔ)句,return其相應(yīng)的數(shù)值代號(hào)。使用lex生成“”2、 構(gòu)造語(yǔ)法分析器首先對(duì)文法進(jìn)行修改去除左遞歸、提取左因子,以及對(duì)“懸空else”、“運(yùn)算優(yōu)先級(jí)”所造成的二義性進(jìn)行消除。之后根據(jù)每個(gè)非終結(jié)符創(chuàng)建一個(gè)函數(shù),實(shí)現(xiàn)各個(gè)函數(shù)的功能。這個(gè)可以模仿實(shí)驗(yàn)一。不過(guò)與實(shí)驗(yàn)一不同的是,這里采用ylex()讀入下一個(gè)終結(jié)符。3、 測(cè)試設(shè)計(jì)采用文件的方式進(jìn)行測(cè)試。在main函數(shù)里輸入文件名,將文件讀入緩沖區(qū)。五、實(shí)驗(yàn)結(jié)果六、心得體會(huì)剛開始覺得這個(gè)實(shí)驗(yàn)比較難,無(wú)從下手。不知道如何調(diào)用yylex(),以及如何修改.l文件。后來(lái)參考了葉柯同學(xué)的代碼,發(fā)現(xiàn)其實(shí)也不是很難。本次實(shí)驗(yàn)除了知識(shí)上的收獲外,更大的收獲是懂得
溫馨提示
- 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ù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年和平中康九和中醫(yī)門診招聘制工作人員考試真題
- 2025年度委托招聘合同-新能源行業(yè)技術(shù)人才
- 2025年度父母贈(zèng)與子女教育基金合同書
- 2025年度全國(guó)青少年籃球聯(lián)賽參賽球隊(duì)贊助合同
- 賓館客房翻新合同協(xié)議書
- 原煤加工合同范本模板
- 2025年度能源節(jié)約合同履行節(jié)能減排個(gè)原則執(zhí)行書
- 2025年度房屋租賃合同解除后的合同終止協(xié)議
- 個(gè)人租用塔吊合同范本
- 2025年度房屋買賣及智能家居安防系統(tǒng)安裝合同
- 23G409先張法預(yù)應(yīng)力混凝土管樁
- 人教版小學(xué)三年級(jí)下冊(cè)數(shù)學(xué)應(yīng)用題專項(xiàng)練習(xí)題40614
- 短視頻抖音運(yùn)營(yíng)培訓(xùn)課程
- 醫(yī)生個(gè)人學(xué)習(xí)心得五篇
- 合規(guī)理論知識(shí)考核試題題庫(kù)及答案
- 新版人教版七年級(jí)下冊(cè)語(yǔ)文全冊(cè)課件(2020最新版)
- MSDS物質(zhì)安全技術(shù)資料-洗面水
- 河南省地圖含市縣地圖矢量分層地圖行政區(qū)劃市縣概況ppt模板
- 績(jī)效管理全套ppt課件(完整版)
- 推進(jìn)優(yōu)質(zhì)護(hù)理-改善護(hù)理服務(wù)-PPT課件
- T∕CNFAGS 3-2021 三聚氰胺單位產(chǎn)品消耗限額
評(píng)論
0/150
提交評(píng)論