資源描述:
《編譯原理課程設(shè)計(jì)-一個(gè)簡單文法編譯器的設(shè)計(jì)與實(shí)現(xiàn)》由會員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫。
1、課程設(shè)計(jì)報(bào)告設(shè)計(jì)題目:一個(gè)簡單文法編譯器的設(shè)計(jì)與實(shí)現(xiàn)班級:計(jì)算機(jī)1302組長學(xué)號:組長姓名:指導(dǎo)教師:設(shè)計(jì)時(shí)間:2015年12月1設(shè)計(jì)分工1摘要現(xiàn)代計(jì)算機(jī)的程序很多都是用高級語言編寫的,而這些高級語言計(jì)算機(jī)是無法識別的,因此需要將它們轉(zhuǎn)變成計(jì)算機(jī)能識別的語言,此時(shí)就需要借助到編譯程序。編譯程序是一種翻譯程序,它特指把某種高級語言(如C、Java、Pascal)翻譯成具體計(jì)算機(jī)上的低級程序設(shè)計(jì)語言。編譯程序是計(jì)算機(jī)系統(tǒng)軟件最主要的組成部分之,也是用戶最直接關(guān)系的工具之一。一個(gè)編譯程序的可以劃分為前端和后端。前端包括詞法分析、語法
2、分析、語義分析與中間代碼生成三個(gè)階段,后端包括優(yōu)化、目標(biāo)代碼生成兩個(gè)階段,另外還有符號表的管理和錯(cuò)誤處理貫穿整個(gè)過程。一個(gè)編譯程序,既可以一個(gè)階段一個(gè)階段地對源程序進(jìn)行分析,也可以前端只對源程序進(jìn)行一遍分析,后端也只進(jìn)行一遍分析。本課設(shè)實(shí)現(xiàn)了對C語言中的一部分功能的編譯,包括算術(shù)邏輯表達(dá)式、if語句、while語句以及一維數(shù)組等。前端對源程序掃描一遍實(shí)現(xiàn)詞法分析、語法分析、語義分析與中間代碼生成三個(gè)階段,后端進(jìn)行目標(biāo)代碼生成,整個(gè)過程穿插符號表管理和錯(cuò)誤處理。關(guān)鍵詞:編譯程序,前端,后端63目錄摘要..............
3、.........................................I1概述....................................................12課程設(shè)計(jì)任務(wù)及要求......................................22.1設(shè)計(jì)任務(wù)..........................................22.2設(shè)計(jì)要求...........................................23算法與數(shù)據(jù)結(jié)構(gòu)..........
4、.................................33.1算法的總體思想(流程).............................33.2詞法分析識別器模塊.................................43.2.1功能.........................................43.2.2數(shù)據(jù)結(jié)構(gòu).....................................53.2.3算法.......................................
5、..93.3語法分析模塊......................................113.3.1功能........................................113.3.2數(shù)據(jù)結(jié)構(gòu)....................................123.3.3算法........................................163.4語義分析和中間代碼生成模塊........................303.4.1功能....................
6、....................303.4.2數(shù)據(jù)結(jié)構(gòu)....................................313.4.3算法........................................333.5符號表模塊........................................413.5.1功能........................................413.5.2數(shù)據(jù)結(jié)構(gòu)....................................4163
7、3.5.3算法........................................433.6目標(biāo)代碼生成模塊..................................433.6.1功能........................................433.6.2數(shù)據(jù)結(jié)構(gòu)....................................443.6.3算法........................................454程序設(shè)計(jì)與實(shí)現(xiàn).................
8、.........................474.1程序流程圖........................................474.2程序說明..........................................474.3實(shí)驗(yàn)結(jié)果...