编译技术课程设计报告精品.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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(); } }

文档评论(0)

rovend + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档