- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理实验报告
一.实验目的:
熟练掌握PLO语言编译程序的结构和功能;
二.实验要求:
扩充PLO语言的功能,增加for语句和case语句;已知for语句和case语句的语法如下:
for语句::=for(赋值语句;关系表达式) do 语句
关系表达式::=表达式关系运算符表达式
case语句::=case标识符:{常量:语句}endcase .
实验环境与工具:
(1)计算机及操作系统:WindowsXP
(2)程序设计语言:C
(3)编译程序:PL/0
(4)实现工具(平台):VC++6.0
设计方案:
概述:
源语言:pl0
目标语言:类pcode代码
实现工具(平台):VC++6.0
结构设计说明:
PlO所有子程序如下:
过程或函数名 简要功能说明 main 初始化编译环境,建立关键字表,调用分程序Block对源文件进行编译,当编译正确时,自动调用解释执行程序,对目标代码进行解释执行。 error 出错处理,打印出错位置和错误性质编号。并在信息栏输出错误信息。 getch 过滤空格,读取一个字符 getsym 词法分析,读取一个单词 gen 生成目标代码(类pcode代码),并送入目标程序区。 test 测试当前单词是否是合法 block 分程序分析处理过程。 enter 登录过程说明对象包括变量、常量和过程名的属性信息到符号表。 position 查找标识符在符号表中的位置。 constdeclaration 常量定义处理,收集常量信息并登录到符号表。 vardeclaration 变量定义处理,收集变量信息并登录到符号表。 listcode 列出目标代码清单。 statement 语法分析,语句部分处理。 expression 表达式分析处理。 term 项分析处理过程。 factor 因子分析处理。 condition 条件处理。 interpret 对目标代码进行解析执行。 Base 通过静态链求数据区首地址。 增加for语句:
设计思想:
For语句的语法分析:
for语句::=for(赋值语句;关系表达式) do 语句
设计思路:
主要分为两部分模块:一,for和;之间的赋值语句处理;二,条件语句处理和最后的语句处理。
(首先获取赋值号左边的标识符,从符号表中找到它的信息,并确认这个标识符确为变量名。然后通过调用表达式处理过程算得赋值号右部的表达式的值并生成相应的指令保证这个值放在运行期的数据栈顶。最后通过前面查到的左部变量的位置信息,生成相应的STO指令,把栈顶值存入指定的变量的空间,实现了赋值操作。返回函数值也是用赋值语句进行返回值的储存。
(首先调用condition函数处理条件语句,并且把当前condition处理生成的判断条件操作代码的的地址cx保存到cx1。每个循环体中,在循环体结束前,设置跳回判断操作判断当前条件是否跳出循环。都把本循环体结束的下一个位置保存到cx2生成跳转,并在循环结束时用cx2更新为目前循环结束跳转地址。
难点分析:本模块,主要难点是处理循环体的跳转,解决方法参照上(点。不过可以参照if语句和while语句。
扩充代码:
1)在头文件pl0.h中的符号symbol中增加所要求增加的符号,用加粗倾斜红色字体标出:
2)源代码:
if(sym==forsym) /* 准备按照for语句处理 */
{
getsymdo;
if(sym==ident) /* 按照赋值语句处理 */
{
i=postion(id,*ptx);
if(i==0)error(11); /* 变量未找到 */
else
{
if(table[i].kind!=variable)
{
error(12); /* for语句格式错误或者赋值语句格式错误 */
i=0;
}
}
getsymdo;
if(sym==becomes)
{
getsymdo;
}
else error(13); /* 检测赋值符号 */
memcpy(nxtlev,fsys,sizeof(bool)*symnum);
expressiondo(nxtlev,ptx,lev); /* 处理赋值符号右侧表达式 */
if(i!=0)
{
gendo(sto,lev-table[i].level,table[i].adr); /* expression将执行一系列指令,但
您可能关注的文档
- 详解javascript,ES5标准中新增的几种高效Object操作方法.doc
- 详略得当写“牛师”(10月17日设计第四稿4:3版本).ppt
- 诚信做人到永远wps.pptx
- 华美 六年级复习题 058----2.doc
- 诗词扩展阅读-一轮复习.pptx
- 华科大附中2016届高三理综测试题八20160216.docx
- PDCA循环经典案例分析 2.ppt
- 华美实验学校2016届高三生物限时训练11限时训练11.doc
- 华侨城苏河湾年营销策略.ppt
- PDF电子签章系统产品白皮书.doc
- 广电行业综合信息(2024年第10期)-China Radio and TV Industry Info(2024-10).pdf
- 人工智能、增长与就业-政策的作用 (Artificial Intelligence, Growth and Employment-The Role of Policy).pdf
- 人工智能时代语言研究中的伦理问题-Ethical Issues in Language Research in the AI Era.pdf
- 2025年人工智能产业展望-全球趋势-AI Industry Outlook 2025-Global Trends.pdf
- 农村增活力:县域城乡融合促进乡村全面振兴的路径探索.pdf
- 数字普惠金融如何驱动乡村产业振兴.pdf
- 统筹新型城镇化和乡村全面振兴研究.pdf
- 新质生产力视域下乡村文化振兴的驱动逻辑与实践路径.pdf
- 金融科技如何驱动乡村产业振兴.pdf
- 新质生产力助推乡村产业振兴的价值、困境和实践进路.pdf
最近下载
- 12 全国生态环境监测专业技术人员大比武理论试题集 第十二章 综合分析 .pdf VIP
- GB51004-2015建筑地基基础工程施工规范.doc VIP
- 致敏物质控制措施检查记录表.docx VIP
- 智慧水利大数据信息化集成服务平台建设综合解决方案.docx VIP
- 城市公共交通规划与运输(1).pptx VIP
- 14 全国生态环境监测专业技术人员大比武理论试题集 第十四章 理论考试试题真题 .pdf VIP
- 2023年南宁市青秀区总工会招聘考试真题.docx VIP
- 烟淄管道干线扩能改造工程 环境影响报告书.pdf VIP
- GB50391-2014:油田注水工程设计规范.pdf VIP
- 资源管理平台系统-技术方案.docx VIP
文档评论(0)