- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译技术课程设计报告精品
编译技术课程设计
班 级 软件1001
学 号
姓 名
指导老师
2013年 6 月
目 录
一、目的 2
二、任务及要求 2
三、实验环境 4
四、实现过程说明 4
1.词法分析器 4
(1)单词符号表 4
(2)数据结构 4
(3)函数说明 5
(4)流程图 5
2.语法分析器 7
(1)分析方法说明 7
(2)文法 7
(3)数据结构 9
(4)函数说明 10
3.中间代码生成器 10
(1)属性文法 10
(2)数据结构 10
(3)函数说明 11
(4)流程图 11
五、程序运行结果 12
六、总结 19
一、目的编译技术是理论与实践并重的课程,而其课程设计要综合运用一、二年级所学的多门课程的内容,用来完成一个小型编译程序。从而巩固和加强对词法分析、语法分析、语义分析、代码生成和报错处理等理论的认识和理解;培养学生对完整系统的独立分析和设计的能力,进一步培养学生的独立编程能力。
二、任务及要求 8 = ( + 9 + ( * 10 * ( ** 11 ** ( ( 12 ( ( / 13 / ( 14 relop MT = 14 relop ME 14 relop LT = 14 relop LE == 14 relop EQ != 14 relop UEQ ; 15 ; ( , 16 , ( ( 17 ( LB ) 17 ) RB 18 Op - || 19 Op -
对于这个小语言,有几点重要的限制:
首先,所有的关键字(如if﹑while等)都是“保留字”。所谓的保留字的意思是,用户不得使用它们作为自己定义的标示符。例如,下面的写法是绝对禁止的:
if(5)=x
其次,由于把关键字作为保留字,故可以把关键字作为一类特殊标示符来处理。也就是说,对于关键字不专设对应的转换图。但把它们(及其种别编码)预先安排在一张表格中(此表叫作保留字表)。当转换图识别出一个标识符时,就去查对这张表,确定它是否为一个关键字。
再次,如果关键字、标识符和常数之间没有确定的运算符或界符作间隔,则必须至少用一个空白符作间隔(此时,空白符不再是完全没有意义的了)。例如,一个条件语句应写为
if i0 i= 1;
而绝对不要写成
ifi0 i=1;
因为对于后者,我们的分析器将无条件地将ifi看成一个标识符。
这个小语言的单词符号的状态转换图,如下图:
语法分析器 能识别由加+ 乘* 乘方** 括号()操作数所组成的算术表达式,其文法如下:
E→E+T|T
T→T*F|F
F→P**F|P
P→(E)|i
使用的算法可以是:预测分析法; 主流程图
N
Y
Y
N
N
N
Y
N
2.语法分析器
(1)分析方法说明
语法分析阶段的基本任务是将词法分析阶段产生的二元组作为输入,根据语言的语法规则,识别出各种语法成分,并判断该单词符号序列是否是该语言的一个句子。
程序采用的是递归下降分析法,这是一种自上而下的分析方法,文法的每个非终结符对应一个递归过程。分析过程就是从文法开始符号出发执行一组递归过程,这样向下推导直到推出句子;或者从跟节点出发,自上而下输入串寻找一个最左匹配序列,建立一棵语法树。
/* 预测分析法;E→E+T|T
T→T*F|F
F→F-P|P**F|P
P→(E)|i
改造后的文法:
E→TE’
E’→+TE’
T→FT’
T’→*FF’
F→P**FF’
F→PF’
F’→-PF’
P→(E)
P→i
递归子程序:
void match(int t)
{
if(lookahead==t)
{
lookahead=nexttoken();
}
else
{
error1();
}
}
void E()
{
T();
E();
}
void E()
{
if(lookahead==+)
{
match(+);
T();
E();
}
}
void T()
{
F();
T();
}
void T()
{
if(lookahead==*)
{
match(*);
F();
F();
}
else error();
}
void F()
{
P();
if(lookahead==*){
if(lookahead==*)
{
F();
F();
}
}
您可能关注的文档
最近下载
- 光伏电站运行常见故障及技术解决方案.pdf VIP
- 军队文职考试《公共科目》试题与参考答案(2024年).docx VIP
- 生成式AI在小学英语课堂中的应用:教师教学决策优化研究教学研究课题报告.docx
- 初二物理导学案-全一册.pdf VIP
- 邮政企业快递企业安全生产重大事故隐患判定标准解读.pdf VIP
- 人民大2023学术规范和论文写作PPT第2章 选:论文选题与研究设计.pptx VIP
- 2025年中国食品级碳酸氢钠数据监测报告.docx
- 能源与动力工程研究教授——程林同志事迹材料— .doc VIP
- 高中物理竞赛-话题5:多质点在动态多边形顶点的相遇问题和多解问题.doc VIP
- 《提升基层干部管理能力》课件.ppt VIP
文档评论(0)