PL0编译器扩展设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE 1 课程设计(论文) PL/0编译器扩展 系 别 : 计算机科学与技术系 专业(班级): 计算机科学与技术10级本科2班 作者(学号): 付想(51002012038) 指导教师: 邹青青 完成日期: 2013年12月23 日 蚌埠学院教务 PAGE 1 目 录 TOC \o 1-3 \h \z \u 一. 课程设计目的与要求 2 1、课程设计目的 2 2、课程设计要求 2 二. 实验环境与工具 2 三. 课程设计内容 2 1. PL/0语言介绍 2 2. 扩展要求 3 3.扩展分析 3 四.结构设计方案 4 1.结构设计说明: 4 2.各功能模块图示: 4 3.模块结构 4 4. 各功能模块作用表: 5 5. 符号名字表结构: 6 6. 保留关键字枚举结构: 6 7.名字表中标识符枚举类型: 6 8.虚拟机 7 9. 运行时存储组织和管理 7 10. 扩充部分语法描述图: 8 11. 扩充赋值运算:+= 和 -= 设计: 9 12.扩充语句(Pascal的FOR语句) 10 13. 增加运算:++ 和 -- : 13 五.程序测试 19 5.1扩充赋值运算:+= 和 -= 19 5.2 扩充语句(Pascal的FOR语句): 19 5.3增加运算:++ 和 --。 21 六.实验总结 22 参考文献 23 附录 源代码 23 课程设计目的与要求 1、课程设计目的 《编译原理》课程设计是编译原理课程必不可少的一个环节,通过课程设计,加深对编译原理的教学内容的了解,以及实现编译原理各部分知识的融合。进而提高学生分析问题、解决问题,从而运用所学知识解决实际问题的能力。 在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序、语法分析程序和语义处理程序进行部分修改扩充。达到进一步了解程序编译过程的基本原理和基本实现方法的目的。 2、课程设计要求 1.明确课设任务,复习与查阅有关资料。 2.按要求完成课设内容,课设报告要求文字和图工整、思路清楚、正确。 3.注意增强程序界面的友好性。凡用户输入时,给出足够的提示信息使用户感到方便使用。 4.注意提高程序的可读性和可理解性:程序中应有适当的注释,变量命名应符合实际含义,程序结构清晰,易于阅读和理解。 实验环境与工具 1.计算机及操作系统:PC机,WindowsXP 2.程序设计语言: VC++ 6.0, C/C++语言 3.教学型编译程序:PL/0 课程设计内容 1. PL/0语言介绍 PL/0程序设计语言是一个较简单的语言,它以赋值语句为基础,构造概念有顺序、条件和重复(循环)三种。PL/0有子程序概念,包括过程定义(可以嵌套)与调用且有局部变量说明。PL/0中唯一的数据类型是整型,可以用来说明该类型的常量和变量。当然PL/0也具有通常的算术运算和关系运算。 2. 扩展要求 (1)扩展一维数组 var 变量名[上界:下界] (2)扩展IF。。。ELSE (3)扩展++,-- (4)扩展+=,-= (5)扩展Repeat。。。Untill(DoWhile) 3.扩展分析 扩充语句的语法描述图如图3-1所示: 图3-1扩充语句语法描述图 A++和A—的语法描述图如图3-2所示: 图3-2A++和A—的语法描述图 ++A和—A的语法描述图如图3-3所示: 语句: 图3-3++A和—A的语法描述图 四.结构设计方案 1.结构设计说明: PL/0的编译程序以语法分析程序为核心,词法分析程序和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就用词法分析程序,而当语法分析正确需生成相应的目标代码时,则调用代码生成程序。此外,用表格管理程序建立变量,常量和过程标识符的说明与引用之间的信息联系。用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错误性质。 2.各功能模块图示: 各功能模块如图4-1所示: 图4-1各功能模块图 3.模块结构 对各种类型的管理; 对返回值的处理; 对for语句的处理; 对case语句的处理; 主要模块的调用关系如下图4-2所示: main main init close in_set printerr genecode filltable set_combination set_multiple set_substrack getsym senantic getch deal_expression deal_term deal_statement deal_cond

文档评论(0)

153****9595 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档