- 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编辑器扩大__ __
学 院 计算机学院
专 业 软件工程
年级班别 10级4班
学 号 3110006379
学生姓名 陈泳鑫
指导教师 杨劲涛
辩论
程序设计
报告撰写
平时
总成绩
2021 年 1 月 4 日
课程设计目的与要求
1、课程设计目的:
在分析理解一个教学型编译程序〔如PL/0〕的根底上,对其词法分析程序、语法分析程序和语义处理程序进展局部修改扩大。到达进一步了解程序编译过程的根本原理和根本实现方法的目的。
2、课程设计要求:
根本内容〔成绩范围:“中〞、“及格〞或“不及格〞〕
〔1〕扩大赋值运算:*= 和 /=
扩大语句〔Pascal的FOR语句〕:
①FOR 变量:=表达式 TO 表达式 DO 语句
②FOR 变量:=表达式 DOWNTO 表达式 DO 语句
其中,语句①的循环变量的步长为2,
语句②的循环变量的步长为-2。
〔3〕增加运算:++ 和 --。
选做内容〔成绩评定范围扩大到:“优〞和“良〞〕
〔1〕增加类型:① 字符类型; ② 实数类型。
〔2〕扩大函数:① 有返回值和返回语句;② 有参数函数。
〔3〕增加一维数组类型〔可增加指令〕。
〔4〕其他典型语言设施。
二、构造设计方案
构造设计说明:
PL/0的编译程序以语法分析程序为核心,词法分析程序和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就用词法分析程序,而当语法分析正确需生成相应的目标代码时,那么调用代码生成程序。此外,用表格管理程序建立变量,常量和过程标识符的说明与引用之间的信息联系。用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错误性质。
各功能模块图示:
3. 各功能模块作用表:
1
PL0
主程序
2
Error
出错处理,打印出错位置和错误编码
3
GetCh
漏掉空格,读取一个字符
4
GetSym
词法分析,读取一个单词
5
Gen
生成目标代码,并送入目标程序区
6
TEST
测试当前单词符号是否合法
7
ENTER
登录名字表
8
POSITION
查找标识符在名字表中的位置
9
ConstDeclaration
常量定义处理
10
VarDeclaration
变量说明处理
11
ListCode
列出目标代码清单
12
FACTOR
因子处理
13
TERM
项处理
14
EXPRESSION
表达式处理
15
CONDITION
条件处理
16
STATEMENT
语句局部处理
17
Block
分程序分析处理过程
18
BASE
通过静态链求出数据区的基地址
19
Interpret
对目标代码的解释执行程序
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, minus,
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, pr
您可能关注的文档
最近下载
- 四川盆地课件.ppt VIP
- 初中信息技术教材解读 九年级下第二章 物联网.pptx VIP
- 【人教新版】七上第三章 第二节 《世界的地形》教学课件.pptx VIP
- 第7课 三国两晋南北朝时期的科技与文化(课件)-【中职专用】《中国历史》(高教版2023基础模块).pptx VIP
- DB50∕T 1786-2025 门诊安宁疗护服务规范.pdf
- 《蒙牛企业介绍》课件.ppt VIP
- 学生的学习风格.ppt VIP
- 9706.1有源医疗器械检测用-GB_T 42062-2022风险管理报告.docx VIP
- 苯甲苯冷凝器工艺设计(课程设计).doc VIP
- 8、第八单元习作:我的心儿怦怦跳(教学课件)四年级语文上册单元作文(统编版).pptx VIP
原创力文档


文档评论(0)