实 验 报 告课程名称编译原理题目名称 PL/0编译器的扩充学生学院计算机学院专业班级计算机科学与技术12(4) 学号 3112005901 学生姓名柏石先指导教师李杨程序功能完成情况测试用例全面程度学生对所编程序熟悉程度报告格式是否与要求相符报告内容是否准确、全面2014 年 12 月 20 日出错处理函数表格管理函数PL/0 源程序目标代码生成程目标代码生成程目标代码生成程目标代码生成程目标代码生成程一、 实验目的与要求对 PL/0 作以下修改扩充:(1)增加单词:保留字 ELSE,FOR, STEP,UNTIL,DO,RETURN运算符 *= ,/= ,&,|| ,!(2)修改单词:不等号# 改为 <>(3)增加条件语句的ELSE子句,要求:写出相关文法,语法描述图,语义描述图。二、 实验环境与工具1、源语言: PL/0 语言, PL/0 语言是 PASCAL语言的子集,它的编译程序是一个编译解析执行系统,后缀名为.PL0;2、目标语言:生成文件后缀为*.COD 的目标代码3、实现平台: Borland C++Builder 64、运行平台: Windows 8.1三、 结构流程1、 结构设计说明(1)PL/0 语言编译器 PL/0语言可看成是PASCAL语言的子集, 它的编译程序是一个编译解释执行系统。PL/0的目标程序为假想栈式计算机的汇编语言,与具体计算机无关。2、 词法分析程序的设计1235141312109786411空格字母字母数字非字母数字数字数字非数字:= <=非= >=非=, + - ( ⋯⋯四、 开发过程( 一)增加单词:保留字 ELSE,FOR,STEP,UNTIL,DO , RETURN运算符 *= ,/= ,&,|| ,!新增 6 个保留字和5 个运算符,合计11 个单词。其中保留字ELSE,FOR,STEP,UNTIL,DO, RETURN分别对应 ELSESYM,FORSYM, STEPSYM, UNTILSYM,DOSYM,RETURNSYM;运算符 *= ,/= ,& ,|| ,!分别对应TIMESBECOMES, SLASHBECOMES, ANDSYM, ORSYM, NOTSYM。注:要求只做词法分析部分,不做语义分析处理,实验的结果只是识别新增的保留字和运算符,并且将其打印显示出来。运算符*=/=&||!SYM表示TIMESBECOMES SLASHBECOMESANDSYM ORSYM NOTSYM1. 首先考虑需要增加保留字的个数,以及如何命名, 再将新增的保留字添加对应的保留字的集合中。具体实现的语句如下所示:typedef enum { NUL, IDENT, NUMBER, PLUS, MINUS, TIMES, SLASH, ODDSYM, EQL, NEQ, LSS, LEQ, GTR, GEQ, LPAREN, RPAREN, COMMA, SEMICOLON, PERIOD, BECOMES, BEGINSYM, ENDSYM,...