- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PL0编译原理课程设计(3109006080何路生)
课 程 设 计
课程名称___ 编译原理______ __
题目名称__编译原理课程设计__ _
学生学院__ 计算机学院_________
专业班级_ 09级计科5班 _
学 号 3109006080
学生姓名____ 何路生___________
指导教师_______张巍____________
2011 年 12 月29 日
课程设计目的
在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序、语法分析程序和语义处理程序进行部分修改扩充。达到进一步了解程序编译过程的基本原理和基本实现方法的目的。
课程设计要求
课内实验:
对PL/0作以下修改扩充:
(1)增加单词:保留字 ELSE,FOR,STEP,UNTIL,RETURN
运算符 +=,-=,++,--,∧,∨,┓
(2)修改单词:不等号# 改为
(3)增加条件语句的ELSE子句,要求:写出相关文法,语法图,语义规则。
课程设计:
基本内容(成绩范围:“中”、“及格”或“不及格”)
(1)扩充赋值运算:+= 和 -=
(2)扩充语句(Pascal的FOR语句):
FOR 变量:=表达式 STEP 表达式UNTIL 表达式 DO 语句
(3)增加运算:++ 和 --。
选做内容(成绩评定范围扩大到:“优”和“良”)
(1)增加类型:① 字符类型; ② 实数类型。
(2)扩充函数:① 有返回值和返回语句;② 有参数函数。
(3)增加一维数组类型(可增加指令)。
(4)其他典型语言设施。
课程设计环境与工具
(1)计算机及操作系统:PC机,Windows7
(2)实现工具:C++Builder6
(3)教学型编译程序:PL/0
结构设计说明
PL/0编译程序的结构图
PL/0编译程序的过程或函数的功能表
1、 void Error(int n) :错误处理,打印出错位置和错误编码
2、 void GetCh():漏掉空格,读取一个字符
3、 void GetSym():词法分析,读取一个单词
4、 void GEN(FCT X, int Y, int Z):生成目标代码,并送入目标程序区
5、 void TEST(SYMSET S1, SYMSET S2, int N):测试当前单词符号是否合法
6、 void ENTER(OBJECTS K, int LEV, int TX, int DX):登录名字表
7、 int POSITION(ALFA ID, int TX):查找标识符在名字表中的位置
8、void ConstDeclaration(int LEV,int TX,int DX):常量说明处理
9、 void VarDeclaration(int LEV,int TX,int DX):变量说明处理
10、void CharDeclaration(int LEV,int TX,int DX):字符说明处理
11、void RealDeclaration(int LEV,int TX,int DX):实数说明处理
12、void ListCode(int CX0):列出目标代码清单
13、void FACTOR(SYMSET FSYS, int LEV, int TX) :因子处理
14、void TERM(SYMSET FSYS, int LEV, int TX) :项处理
15、void EXPRESSION(SYMSET FSYS, int LEV, int TX):表达式处理
16、void CONDITION(SYMSET FSYS,int LEV,int TX) :条件处理
17、void STATEMENT(SYMSET FSYS,int LEV,int TX) :语句部分处理
18、void Block(int LEV, int TX, SYMSET FSYS) :分程序分析处理过程
19、int BASE(int L,int B,int S[]):通过静态链求出数据区的基地址
20、void Interpret() :对目标代码的解释执行程序
21、void __fastcall TForm1::ButtonRunClick(TObject *Sender):进行编译,RUN
词法分析
词法分析是编译的第一个阶段,它的主要任务是从左向右逐个字符地对源程序进行扫描,产生一个个单词序列用于语法分析。PL/0词法分析程序GETSYM的功能是为语法分析提供单词用的,是语法分析的基础,把输入的字符串形式的源程序分割成一个个单词符号。经过词法分析程序分析出来的单词,对语言固有的单词只给出类别存放在全程变量SYM中,而对用户定义的单词(标识符或常数)既给出类别又
您可能关注的文档
- 2015年高三交变电流专题.doc
- 220kV变电所的日常运行值班工作.doc
- 21区域地质概况与气藏地质特征.doc
- 220kV奚仲变电站基础基本完成阶段中间验收报告.doc
- 220kV电气设备试验作业指导书.doc
- 220kV西湖变电站防火封堵项目技术方案书.doc
- 220kV变电站设计满意经典.doc
- 220kV降压变电所短路电流的计算.doc
- 28标准物质管理程序3.doc
- 2主变ABC滤油施工方案.doc
- 两角和与差的正弦公式教学设计.doc
- 2025年回收产业:新能源汽车电池回收产业发展现状与未来趋势报告.docx
- 2025年无人机市场增长前景与政策法规影响评估报告.docx
- 直播电商行业监管规范标准分析:2025年现状与未来十年市场潜力报告.docx
- 2025年AI生成版权纠纷案例解析报告:版权法律风险防控.docx
- 2025年新能源行业人才政策分析与产业需求对接研究报告.docx
- Unit 2 Amazing Numbers Section 2 grammar课件 沪教版八年级上册.pptx
- 新概念英语三 Lesson 53 In the public interest课件.pptx
- 1.4 人耳听不到的声音 课件 物理苏科版(2024)八年级上册.pptx
- 14.3 热机的效率 物理人教版(2024)九年级全一册.pptx
文档评论(0)