已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
报告成绩实 验 报 告项目名称 PL/0语言的扩充 学 院 计算机学院 专业班级 09软件工程1班 学 号 3109006291 姓 名 姚振威 指导教师 李小妹 程序功能完成情况测试用例全面程度学生对所编程序熟悉程度报告格式是否与要求相符报告内容是否准确、全面2011 年 12 月 28 日实验一:增加单词 一、 实验目的与要求在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序。二、 实验内容增加单词:保留字 ELSE,FOR,TO,DOWNTO,RETURN运算符 +=,-=,+,-,&,|,!实验平台(1)计算机及操作系统:PC机,Windows7(2)程序设计语言:C+Builder(3)集成环境:C+Builder (4)教学型编译程序:PL/0三、 设计方法首先要扩展SYMBOL,在此基础上再进行其它细节的修改。要添加的SYMBOL为:typedef enum 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, PROGSYM, , ELSESYM,FORSYM, TOSYM, DOWNTOSYM, RETURNSYM, PLUSBECOMES,MINUSBECOMES, DPLUS, DMINUS,AND,OR,NOT SYMBOL;char *SYMOUT = 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, PROGSYM, ELSESYM,FORSYM, TOSYM, DOWNTOSYM, RETURNSYM, PLUSBECOMES,MINUSBECOMES, DPLUS, DMINUS ,AND,OR,NOT ;其中红斜体为新加入的SYMBOL。再将ELSESYM,FORSYM, TOSYM, DOWNTOSYM, RETURNSYM, PLUSBECOMES,MINUSBECOMES, DPLUS, DMINUS关键字加到KWORD和将相应的SYM加到WSYM,按字母顺序排列。以及修改NEQ 后如下for (CH= ; CH=; CH+) SSYMCH=NUL; strcpy(KWORD 1,BEGIN); strcpy(KWORD 2,CALL); strcpy(KWORD 3,CONST); strcpy(KWORD 4,DO); strcpy(KWORD 5,DOWNTO);strcpy(KWORD 6,ELSE); strcpy(KWORD 7,END); strcpy(KWORD 8,FOR); strcpy(KWORD 9,IF);strcpy(KWORD10,ODD); strcpy(KWORD11,PROCEDURE);strcpy(KWORD12,PROGRAM); strcpy(KWORD13,READ);strcpy(KWORD14,RETURN); strcpy(KWORD15,THEN); strcpy(KWORD16,TO); strcpy(KWORD17,VAR);strcpy(KWORD18,WHILE); strcpy(KWORD19,WRITE); WSYM 1=BEGINSYM; WSYM 2=CALLSYM; WSYM 3=CONSTSYM; WSYM 4=DOSYM; WSYM 5=DOWNTOSYM; WSYM 6=ELSESYM; WSYM 7=ENDSYM; WSYM 8=FORSYM; WSYM 9=IFSYM; WSYM10=ODDSYM; WSYM11=PROCSYM; WSYM12=PROGSYM; WSYM13=READSYM; WSYM14=RETURNSYM; WSYM15=THENSYM; WSYM16=TOSYM; WSYM17=VARSYM; WSYM18=WHILESYM; WSYM19=WRITESYM; SSYM+=PLUS; SSYM-=MINUS;/用于SYM=SSYMCH; SSYM*=TIMES; SSYM/=SLASH; SSYM(=LPAREN; SSYM)=RPAREN; SSYM=EQL; SSYM,=COMMA; SSYM.=PERIOD; / SSYM#=NEQ;/不等号#改为,#用不上删除 SSYM;=SEMICOLON;SSYM&=AND; SSYM|=OR; SSYM!=NOT; strcpy(MNEMONICLIT,LIT); strcpy(MNEMONICOPR,OPR); strcpy(MNEMONICLOD,LOD); strcpy(MNEMONICSTO,STO); strcpy(MNEMONICCAL,CAL); strcpy(MNEMONICINI,INI); strcpy(MNEMONICJMP,JMP); strcpy(MNEMONICJPC,JPC);因为保留字增加了5个,所以令const NORW = 19;SYMBOL由原来的33个值扩展为目前的42个值,SYMOUT也由原来的33个元素扩展为目前的42个元素.我用个SYMMAX来记录SYMBOL值的个数, 所以,在与单词个数有关的函数中,用“SYMMAX”替代“33”,即除了Error函数中可能出现的作为参数的“33”不被替换为“42”外,其余的“33”均用“SYMMAX”来替换。如:S=(SYMSET)malloc(sizeof(int)*SYMMAX);for (i=0; iSYMMAX; i+) Si=0;SYMBOL扩展完毕。对运算符 +=,- =,+,-词法分析增添:if(CH=+) GetCh(); if(CH=) SYM=PLUSEQ; GetCh(); else if(CH=+) SYM=PLUSSF; GetCh(); else SYM=PLUS; else if(CH=-) GetCh(); if(CH=) SYM=MINUSEQ; GetCh(); else if(CH=-) SYM=MINUSSF; GetCh(); else SYM=MINUS; 四、 心得体会熟悉了PL0的词法分析,即Getch()修改和添加。设计前感觉很简单,但当自己动手去做后才发现挺多要注意的细节的东西。实验二:修改单词 一、 实验目的与要求在分析理解一个教学型编译程序(如PL/0)的基础上,进一步对词法分析程序理解,扩充。二、 实验内容修改单词:不等号# 改为 (NEQ)实验平台(1)计算机及操作系统:PC机,Windows7(2)程序设计语言:C+Builder(3)集成环境:C+Builder (4)教学型编译程序:PL/0三、 设计方法只要修改GetSym()函数。当编译器检测到当前字符为“”时,接着检测下一个字符,如果是“”,则使SYM=NEQ。代码修改如下:if (CH=) SYM=NEQ; GetCh(); else SYM=LSS;同时SSYM#=NEQ;用不上可删除。四、 测试五、 心得体会有实验一的基础,本实验相对来说很简单,只要像实验一一样在Getsym()里面修改一下就可以了。实验三::增加条件语句的ELSE子句 一、 实验目的与要求在前两个实验的基础上,实现ELSE语句的语法语义扩充。二、 实验内容增加条件语句的ELSE子句,要求:写出相关文法,语法图,语义规则。实验平台(1)计算机及操作系统:PC机,Windows7(2)程序设计语言:C+Builder(3)集成环境:C+Builder (4)教学型编译程序:PL/0三、 设计方法该条件语法描述图如下:只要在STATEMENT修改如下代码:case IFSYM:GetSym();CONDITION(SymSetUnion(SymSetNew(THENSYM,DOSYM),FSYS),LEV,TX);if (SYM=THENSYM) GetSym();else Error(16);CX1=CX; GEN(JPC,0,0);STATEMENT(SymSetUnion(SymSetNew(ELSESYM,DOSYM),FSYS),LEV,TX); CODECX1.A=CX; /没有ELSE时候CX1的回填 if (SYM=ELSESYM) GetSym(); CX2=CX; GEN(JMP,0,0);/执
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 一种过滤式除尘器防集尘快速更换滤芯装置
- 产妇产后卧床恢复护理操作流程
- 台风来临大型设备吊装警戒区域防护方案
- 宠物美容预约加急处理制度
- 生产部安全生产责任制度细则
- 涂装车间干燥温度波动改善方案
- 暖通设备接口隐蔽工程验收交底方案
- 证照保管单位职责明晰细则
- 麻醉诱导苏醒期管理流程
- 五轴铣削刀具寿命优化制度
- 浙江省金华市(2026年)辅警协警笔试笔试真题(附答案)
- 2026年3年级竞赛试题及答案
- 养老护理员工作倦怠与应对
- 2026山西晋中市寿阳县国有资本运营有限公司及下属公司中高层管理人员招聘12人考试备考题库及答案解析
- 2026年3月15日九江市五类人员面试真题及答案解析
- 2026“蓉漂人才荟”成都东部新区事业单位公开招聘事业人员(30人)笔试参考题库及答案解析
- 机械类专职安全生产管理人员(C1)题库
- 第5课艰辛探索与曲折发展(教学课件)
- 飞机维护技术基础
- 2025年农产品食品检验员职业技能竞赛理论考试题库(含答案)
- PLC基础知识教学课件
评论
0/150
提交评论