- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PL0扩充课程设计报告教程
课 程 设 计
课程名称 编译原理
题目名称 PL/0扩充
学 院
专 业
班 级
学 号
姓 名
指导教师
2011 年 1 月 8 日
课程设计目的与要求
1、课程设计目的:
在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序、语法分析程序和语义处理程序进行部分修改扩充。达到进一步了解程序编译过程的基本原理和基本实现方法的目的。
2、课程设计要求:
基本内容(成绩范围:“中”、“及格”或“不及格”)
(1)扩充赋值运算:+= 和 -=
(2)扩充语句(Pascal的FOR语句):
①FOR 变量:=表达式 TO 表达式 DO 语句
②FOR 变量:=表达式 DOWNTO 表达式 DO 语句
其中,语句①的循环变量的步长为1,语句②的循环变量的步长为-1。
选做内容(成绩评定范围扩大到:“优”和“良”)
(1)增加运算:++ 和 --。
(2)增加类型:① 字符类型; ② 实数类型。
(3)扩充函数:① 有返回值和返回语句;② 有参数函数。
(4)增加一维数组类型(可增加指令)。
(5)其他典型语言设施。
二.实验环境与工具
(1)计算机及操作系统:PC机,WindowsXP
(2)程序设计语言: VC++ 6.0, C/C++语言
(3)教学型编译程序:PL/0
结构设计方案
结构设计说明:
PL/0的编译程序以语法分析程序为核心,词法分析程序和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就用词法分析程序,而当语法分析正确需生成相应的目标代码时,则调用代码生成程序。此外,用表格管理程序建立变量,常量和过程标识符的说明与引用之间的信息联系。用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错误性质。
各功能模块图示:
3. 各功能模块作用表:
1PL0主程序2Error出错处理,打印出错位置和错误编码 3GetCh漏掉空格,读取一个字符 4GetSym词法分析,读取一个单词 5Gen生成目标代码,并送入目标程序区 6TEST测试当前单词符号是否合法 7ENTER登录名字表 8POSITION查找标识符在名字表中的位置 9ConstDeclaration常量定义处理10VarDeclaration变量说明处理11ListCode列出目标代码清单12FACTOR因子处理13TERM项处理14EXPRESSION表达式处理15CONDITION条件处理16STATEMENT语句部分处理17Block分程序分析处理过程18BASE通过静态链求出数据区的基地址19Interpret对目标代码的解释执行程序
3. 符号名字表结构:
struct tablestruct
{
char name[al]; /*名字*/
enum object kind; /*类型:const,var,array or procedure*/
int val; /*数值,仅const使用*/
int level; /*所处层,仅const不使用*/
int adr; /*地址,仅const不使用*/
int size; /*需要分配的数据区空间,仅procedure使用*/
};
4. 保留关键字枚举结构:
enum symbol{
nul, ident, number, plus, dplus, eplus, minus, dminus, eminus,
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, el
您可能关注的文档
- Physics-of-Semiconductor-Devices教程.ppt
- PID参数整定MATLAB仿真教程.docx
- PhotoshopCS5完全入门自学教程71页版教程.ppt
- PID控制最通俗的解释与PID参数的整定方法及S7200PID应用教程.doc
- pintos抢占式优先级教程.docx
- PinAAcle原子吸收光谱仪软件简明教程-AA900F版教程.doc
- photoshop讲义-4教程.doc
- PIS车地无线系统LTE技术方案新版教程.docx
- Pioneer0223版本VOLTE测试操作方法更新教程.pptx
- PICC置管流程教程.ppt
- 银发旅游市场2025:需求分析与特色旅游产品创新趋势洞察报告.docx
- 脑机接口技术伦理治理案例:伦理困境与解决方案.docx
- 工业自动化控制网络技术在轻工业中的应用案例及发展趋势报告.docx
- 环保产业土壤修复技术与市场前景分析报告.docx
- 绿色金融创新支持城市绿色交通体系建设的策略研究.docx
- 化工行业2025年智能制造系统集成项目可行性评估报告.docx
- 2025年社区嵌入式养老驿站服务模式创新与品牌建设研究报告.docx
- 医疗影像AI技术在伦理道德审查中的实践探索报告.docx
- 航空物流市场前景分析及航空货运枢纽建设运营管理报告.docx
- 2025年汉服产业文化认同度与市场潜力分析.docx
文档评论(0)