- 1、本文档共56页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
毕业设计论文-cminus词法分析和语法分析设计编译器编译原理设计
编译原理课程设计报告
课题名称: C- Minus词法分析和语法分析设计 提交文档学生姓名: X X X 提交文档学生学号: XXXXXXXXXX 同组 成 员 名 单: X X X 指导 教 师 姓 名: X X 指导教师评阅成绩: 指导教师评阅意见: . . 提交报告时间:2015年6月10日
课程设计目标
实验建立C-编译器。只含有扫描程序(scanner)和语法分析(parser)部分。
分析与设计
C-编译器设计的整体框架,本实验实现扫描处理和语法分析程序(图中粗黑部分)。
2.1 、扫描程序scanner部分
2.1.1系统设计思想
设计思想:根据DFA图用switch-case结构实现状态转换。 惯用词法:
语言的关键字:else if int return void while
专用符号:+ - * / ! ; , [ ] /* */
其他标记是ID和NUM,通过下列正则表达式定义: ID letter letter* NUM digit digit* letter a|..|z|A|..|Z digit 0|..|9
大写和小写字母是有区别的
空格由空白、换行符和制表符组成。空格通常被忽略,除了它必须分开ID、NUM关键字。
注释用通常的C语言符号/ * . . . * /围起来。注释可以放在任何空白出现的位置 即注释不能放在标记内 上,且可以超过一行。注释不能嵌套
说明:当输入的字符使DFA到达接受状态的时候,则可以确定一个单词了。初始状态设置为START,当需要得到下一个token时,取得次token的第一个字符,并且按照DFA与对此字符的类型分析,转换状态。重复此步骤,直到DONE为止,输出token类型。当字符为“/”时,状态转换为SLAH再判断下一个字符,如果为“*”则继续转到INCOMMENT,最后以“*”时转到ENDCOMMENT状态,表明是注释,如果其他的则是字符停滞于当前字符,并且输出“/”。
2.1.2程序流程图
2.1.3 各文件或函数的设计说明
扫描程序用到:scanner.h,scanner.cpp
scanner.h:声明词法状态,词法分析
//DFA中的状态
typedef enum START 1, INNUM, INID, INDBSYM, DONE
DFAState;
//定义的Token的类型 31种 ,分别对应于else、if、int、return、void、while、+、-、*、/、 、 、 、 、 、! 、 、;、,、 、 、[、]、 、 、/*、*/、num、id、错误、结束
typedef enum ELSE 1,IF,INT,RETURN,VOID,WHILE,
PLUS,MINUS,TIMES,OVER,LT,LEQ,GT,GEQ,EQ,NEQ,ASSIGN,SEMI,COMMA,LPAREN,RPAREN,LMBRACKET,RMBRACKET,LBBRACKET,RBBRACKET,LCOMMENT,RCOMMENT,
NUM,ID,ERROR,ENDFILE
TokenType;
//定义的Token结构体,包括类型、对应的串、所在代码的行号
struct Token TokenType tokenType;
string tokenString;
int lineNo;
;
//每种TokenType对应的串,如tokenTypeString[ELSE] ELSE
const string tokenTypeString[32] OTHER, ELSE, IF, INT, RETURN, VOID, WHILE, PLUS, MINUS, TIMES, OVER, LT, LEQ, GT, GEQ, EQ, NEQ, ASSIGN, SEMI, COMMA, LPAREN, RPAREN, LMBRACKET, RMBRACKET, LBBRACKET, RBBRACKET, LCOMMENT, RCOMMENT, NUM, ID, ERROR, ENDFILE ;
class Scanner:定义scanner.cpp中函数
scanner.cpp文件函数说明
void Scanner :: scan :设置输出结果界面以及设置各种输出状态。
if scanSuccess false cout 词法分析出错! endl;
else
cout 词法分析成功了! endl;
printToken ;/*输出Token到文件Token.txt中*/
//正在删除注释
void Scanner :: deleteCommen
您可能关注的文档
- 毕业设计论文-《双城记》中卡顿的悲剧英语论文.doc
- 毕业设计论文-《华西都市报》城管刻板印象研究.doc
- 毕业设计论文-2×660mw超超临界(上大压小)燃煤机组扩建工程电厂化学部分设计说明书.doc
- 毕业设计论文-2×600mw机组烟气系统施工方案.doc
- 毕业设计论文-2cr13活塞杆的热处理工艺设计课程设计论文.doc
- 毕业设计论文-4s店销售管理总设计.doc
- 毕业设计论文-3mwp光伏电站工程项目施工组织设计.doc
- 毕业设计论文-7万吨年500~6000目超细蒙脱石球磨分级生产线工艺流程设计粉体材料课程设计.doc
- 毕业设计论文-5+1档轿车手动变速箱设计说明书.doc
- 毕业设计论文-8t载货汽车后桥鼓式制动器及其控制系统的设计.doc
- [中央]2023年中国电子学会招聘应届生笔试历年参考题库附带答案详解.docx
- [吉安]2023年江西吉安市青原区总工会招聘协理员笔试历年参考题库附带答案详解.docx
- [中央]中华预防医学会科普信息部工作人员招聘笔试历年参考题库附带答案详解.docx
- [保定]河北保定市第二医院招聘工作人员49人笔试历年参考题库附带答案详解.docx
- [南通]江苏南通市崇川区人民法院招聘专职人民调解员10人笔试历年参考题库附带答案详解.docx
- [厦门]2023年福建厦门市机关事务管理局非在编工作人员招聘笔试历年参考题库附带答案详解.docx
- [三明]2023年福建三明市尤溪县招聘小学幼儿园新任教师79人笔试历年参考题库附带答案详解.docx
- [哈尔滨]2023年黑龙江哈尔滨市木兰县调配事业单位工作人员笔试历年参考题库附带答案详解.docx
- [上海]2023年上海市气象局所属事业单位招聘笔试历年参考题库附带答案详解.docx
- [台州]2023年浙江台州椒江区招聘中小学教师40人笔试历年参考题库附带答案详解.docx
最近下载
- 第15课 两次鸦片战争 教学课件(共31张PPT)高中历史人教统编版中外历史纲要上册.pptx VIP
- 电子课件-《GSP实务教程》课题七.pptx VIP
- 电机与电气控制技术 任务后练习题参考答案 赵红顺 .pdf
- PEP人教版小学英语六年级下册教案 全册.pdf VIP
- [北京]2024年北京市文物局局属事业单位招聘笔试历年参考题库附带答案详解.docx
- 【课件】平移(课件)人教版(2024)数学七年级下册.pptx VIP
- 电子课件-《GSP实务教程》课题六.pptx VIP
- 部编版道德与法治五年级下册《读懂彼此的心》练习题.docx VIP
- 《研学旅行课程设计》课件——研学课程方案设计.pptx VIP
- 《Lagrange中值定理.ppt
文档评论(0)