- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE / NUMPAGES
编译技术班 级 网络 0802
学 号 3080610052
姓 名 叶晨舟
指导老师 朱 玉 全
2018年 7 月 4 日
一、目的
编译技术是理论与实践并重的课程,而其实验课要综合运用一、二年级所学的多门课程的内容,用来完成一个小型编译程序。从而巩固和加强对词法分析、语法分析、语义分析、代码生成和报错处理等理论的认识和理解;培养学生对完整系统的独立分析和设计的能力,进一步培养学生的独立编程能力。
二、任务及要求
基本要求:
词法分析器 产生下述小语言的单词序列
这个小语言的所有的单词符号,以及它们的种别编码和内部值如下表:
单词符号
种别编码
助记符
内码值
DIM
IF
DO
STOP
END标识符
常数整)
=
+
*
**
,
)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$DIM$IF$DO$STOP$END$ID$INT$ASSIGN$PLUS$STAR$POWER$COMMA$LPAR$RPAR
-
-
-
-
-
-
内部字符串
标准二进形式
-
-
-
-
-
-
对于这个小语言,有几点重要的限制:
首先,所有的关键字如IF﹑WHILE等)都是“保留字”。所谓的保留字的意思是,用户不得使用它们作为自己定义的标示符。例如,下面的写法是绝对禁止的:
IF5)=x
其次,由于把关键字作为保留字,故可以把关键字作为一类特殊标示符来处理。也就是说,对于关键字不专设对应的转换图。但把它们及其种别编码)预先安排在一张表格中此表叫作保留字表)。当转换图识别出一个标识符时,就去查对这张表,确定它是否为一个关键字。
再次,如果关键字、标识符和常数之间没有确定的运算符或界符作间隔,则必须至少用一个空白符作间隔此时,空白符不再是完全没有意义的了)。例如,一个条件语句应写为
IF i0 i= 1。
而绝对不要写成
IFi0 i=1。
因为对于后者,我们的分析器将无条件地将IFI看成一个标识符。
这个小语言的单词符号的状态转换图,如下图:
语法分析器 能识别由加+ 减- 乘* 除/ 乘方^ 括号)操作数所组成的算术表达式,其文法如下:
E→E+T|E-T|T
T→T*F|T/F|F
F→P^F|P
p→(E|i
使用的算法可以是:预测分析法;递归下降分析法;算符优先分析法;LR分析法等。
中间代码生成器 产生上述算术表达式的中间代码四元式序列)
三、实现过程
给出各题目的详细算法描述,数据结构和函数说明,流程图。
1、词法分析器的流程图
2、语法分析器主程序图
3、中间代码生成器流程图:
四、源程序
词法分析器:
#includestring.h
#includemalloc.h
#includeiostream
using namespace std。
typedef struct table //分析表存储结构
{
char m[100]。
}table。
table M[100][100]。 //定义分析表
typedef struct stacknode //定义栈内元素节点 (带头结点为空)的
{
char data。
struct stacknode *next。
}stackk。
void initlink(stackk *s //初始化新栈
{
s=(stackk *malloc(sizeof(stackk。
s-next=NULL。
}
void poplink(stackk *s //顶元素出栈
{
stackk *p。char v。
if(s-next!=NULL
{
p=s-next。
v=p-data。
s-next=p-next。
}
free(p。
}
void pushlink(stackk *s,char x //新 元 素 入 栈
{
stackk *p。
p=(stackk *malloc(sizeof(stackk。
p-data=x。
p-next=s-next。
s-next=p。
}
void display(stackk *s //打印 现实显示 栈内元素
{
stackk *p
您可能关注的文档
- 篮球竞赛秒计时器设计文案课程设计文案.doc
- 米氏酸在杂环化合物合成中的应用解析研究进展综述.doc
- 米捣固焦炉毕业设计文案[].doc
- 精品培养初中生语文意识的解析研究.doc
- 精品[精品]塑料盖模具设计文案.doc
- 精细化思想的安防系统安装项目管理解析研究.doc
- 精度设计文案互换性齿轮油泵说明书.doc
- 紫外有机电致发光材料解析研究进展.doc
- 紫草素提取工艺及制剂解析研究概况.doc
- 紫山控制测量实习解析方案[].doc
- 人教版数学九年级上册《 二次函数》说课稿(共19张PPT).ppt
- 人教版八年级上册 12.2.2三角形全等的判定 “边角边”判定三角形全等 (共22张PPT).ppt
- 人教版初中数学2011课标版八年级上册第十二章12.2 三角形全等的判定 课件(共16张PPT).ppt
- 人教版九年级第十单元课题1浓硫酸1 (共18张PPT).ppt
- 人教版初中数学七年级上册 1.4 有理数的乘除法(共22张PPT).ppt
- 人教版八年级物理上册第1章 第2节运动的描述习题课件(共20张PPT).ppt
- 人教版九年级课题2酸和碱之间会发生什么反应(共21张PPT).ppt
- 人教版初中物理2011课标版 九年级 第十八章 电功率第三节 测量小灯泡的电功率(共25张PPT).pptx
- 人教版初中数学2011课标版九年级上册第二十四章24.1圆的有关性质(共17张PPT).ppt
- 人教版初中数学2011课标版九年级上册21.2解一元二次方程(共22张PPT).pptx
最近下载
- 电能表及电能表控制方法.pdf VIP
- 2025水利水电工程施工企业主要负责人员安全生产管理三类人员考试题库(含答案).pptx VIP
- 中职数学(基础模块下册)高教版 第五章 指数函数与对数函数 复习题(解析版).docx VIP
- 2024年广州市入团培训考试题库(含答案).docx VIP
- 肿瘤病人的营养护理ppt.pptx
- DB63∕T 2014-2022 公路养护工程机械台班费用定额.docx VIP
- 3.1.7、专业分包施工单位资格报审表.xls VIP
- 2025年浙教版八年级科学上册测试题及答案全套.pdf VIP
- 2025水利水电工程施工企业主要负责人员安全生产管理三类人员考试题库(含答案).pdf VIP
- 001-GD-C1-314 专业分包施工单位报审表.xls VIP
原创力文档


文档评论(0)