已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
编译原理实验报告学 院 专 业 班 级 学 号 姓 名 指导教师 2011 年1 月 8 日 学院 专业 班 组、学号 姓名 协作者_ 教师评定_实验题目 增加单词 一、 实验目的与要求在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序。二、 实验内容增加单词:保留字 ELSE,FOR,TO,DOWNTO,RETURN运算符 += -= + - 三、 设计方法1、首先修改头文件“pl0.h”:enum symbol nul, ident, number,plus, minus, times, slash, oddsym,eql, neq, lss, leq, gtr, geq, lparen, rparen, comma, semicolon,period, becomes, beginsym, endsym, ifsym,thensym, whilesym, writesym, readsym, dosym,callsym, constsym, varsym, procsym, elsesym, forsym, tosym, downtosym, returnsym, pluseql, minuseql, plusplus,minusminus, /*符号枚举体增加5个关键字4个运算符,用黑体字标注*/; # define norw 18 /*关键字个数数由初始值13增加至18 */ #define symnum 41 /*符号数初始值由32增加至41 */ 2、接着修改源程序“PL0.cpp”:/*设置保留字名字,按照字母顺序,便于折半查找*/strcpy(&(word00),begin);strcpy(&(word10),call);strcpy(&(word20),const);strcpy(&(word30),do);strcpy(&(word40),downto); /*增加保留字DOWNTO*/strcpy(&(word50),else); /*增加保留字ELSE*/strcpy(&(word60),end);strcpy(&(word70),for); /*增加保留字FOR*/strcpy(&(word80),if);strcpy(&(word90),odd);strcpy(&(word100),procedure);strcpy(&(word110),read);strcpy(&(word120),return); /*增加保留字RETURN*/strcpy(&(word130),then);strcpy(&(word140),to); /*增加保留字TO*/strcpy(&(word150),var);strcpy(&(word160),while);strcpy(&(word170),write);/*设置保留字符号*/wsym0=beginsym;wsym1=callsym;wsym2=constsym;wsym3=dosym;wsym4=downtosym; /*增加保留字符号downtosym*/wsym5=elsesym; /*增加保留字符号elsesym*/wsym6=endsym;wsym7=forsym; /*增加保留字符号forsym*/wsym8=ifsym;wsym9=oddsym;wsym10=procsym;wsym11=readsym;wsym12=returnsym; /*增加保留字符号returnsym*/wsym13=thensym;wsym14=tosym; /*增加保留字符号tosym*/wsym15=varsym;wsym16=whilesym;wsym17=writesym;在语法分析函数 getsym()添加+ - += -=的符号分析:/* 增加检测+和+=符号 */ else if(ch=+) getchdo;if(ch=) sym=pluseql; /构成+=号getchdo;else if(ch=+) sym=plusplus; /构成+号getchdo;else sym=plus; /*结束*/ /* 增加检测-和-=符号 */ else if(ch=-) getchdo;if(ch=) sym=minuseql; /构成-=号getchdo;else if(ch=-) sym=minusminus; /构成-号getchdo;else sym=minus; /*结束*/四、 心得体会熟悉了PL0的词法分析,了解了程序头文件和初始化函数“init()”的原理和功能,需要知道程序查找时用到了折半查找法,所以添加单词时注意按字典序的方式插入单词。 学院 专业 班 组、学号 姓名 协作者_ 教师评定_实验题目 修改单词 一、 实验目的与要求在分析理解一个教学型编译程序(如PL/0)的基础上,进一步对词法分析程序理解,扩充。二、 实验内容修改单词:不等号# 改为 三、 设计方法因为不为单字符,不能被识别,故去掉原先单字符#的设置部分: /ssym#=neq; 需要在getsym()部分增加不等号语法判断:if(ch=) /*检测小于或小于等于符号*/getchdo;if(ch=) /小于号后不是跟着等号sym=leq; /构成小于等于号 ) /小于号后面跟着大于号 sym=neq; /构成不等号 getchdo;else sym=lss; /小于号 四、 心得体会进一步理解词法分析程序,了解了GetSym()是如何分析单词,仿照前面=符号写法可以实现不等号的语法分析。 学院 专业 班 组、学号 姓名 协作者_ 教师评定_实验题目 增加条件语句的ELSE子句 一、 实验目的与要求在前两个实验的基础上,实现ELSE语句的语法语义扩充。二、 实验内容增加条件语句的ELSE子句三、 设计方法 修改IF THEN ELSE条件语句句法分析流程图: 在 int statement(bool* fsys,int * ptx,int lev) 函数增加else语法判断代码: if(sym=elsesym) /*than语句后面发现else*/ getsymdo;cx2=cx; codecx1.a=cx+1; /*cx为当前的指令地址,cx+1即为then语句执 行后的else语句的位置,回填地址*/gendo(jmp,0,0); statementdo(fsys,ptx,lev); codecx2.a=cx; /*经statement处理后,cx为else后语句执行完的位置,它正是前面未定的跳转地址,回填地址*/else /*than语句后面没有发现else*/cod
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二级教师考试试题及答案
- 钻采工程方案设计
- 防爆变频电器项目可行性研究报告(案例模板)
- 陶瓷研究报告国内陶瓷行业发展趋势及发展策略研究报告(2025年)
- 静安区志丹系统提标调蓄池工程可行性研究报告(初步设计深度)行
- 黄河湿地生态修复工程项目可行性研究报告
- 2026年一级建造师一建市政实务案例分析考前十页纸考点重点知识预测记忆总结笔记
- 承包电杆协议书
- 贷记卡授信协议书
- 建筑智能化安防布线创新创业项目商业计划书
- 冬季钢结构焊接施工技术与费用分析
- 高校思政说课课件
- 2025年教师考试时事政治考点热点题库含完整答案
- 饮品品牌加盟合同范本
- 球馆合伙协议合同模板
- 2024年陕西咸阳杨陵区招聘社区专职工作人员考试真题
- 2025中国光伏组件回收技术发展现状与循环经济战略报告
- 雨课堂在线学堂《军事历史-第二次世界大战史》单元考核测试答案
- 家庭宽带服务质量保障流程规范(2024版)
- 学堂在线 战场侦察监视技术与装备 章节测试答案
- 铁路行车事故应急预案范本
评论
0/150
提交评论