译原理语法分析实验报告.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文档。上传文档
查看更多
编译原理 实验报告-语法分析 班级:XXX 学号:XXX 姓名:XXX 年 月 日 摘要: 用递归子程序法实现对pascal的子集程序设计语言的分析程序 实验目的: 通过完成语法分析程序,了解语法分析的过程和作用 任务概述 实验要求:对源程序的内码流进行分析,如为文法定义的句子输出”是”否则输出”否”,根据需要处理说明语句填写写相应的符号表供以后代码生成时使用 实验依据的原理 递归子程序法是一种自顶向下的语法分析方法,它要求文法是LL(1)文法。通过对文法中每个非终结符编写一个递归过程,每个过程的功能是识别由该非终结符推出的串,当某非终结符的产生式有多个候选式时,程序能够按LL(1)形式唯一地确定选择某个候选式进行推导,最终识别输入串是否与文法匹配。 递归子程序法的缺点是:对文法要求高,必须满足LL(1)文法,当然在某些语言中个别产生式的推导当不满足LL(1)而满足LL(2)时,也可以采用多向前扫描一个符号的办法;它的另一个缺点是由于递归调用多,所以速度慢占用空间多,尽管这样,它还是许多高级语言,例如PASCAL,C等编译系统常常采用的语法分析方法。 为适合递归子程序法,对实验一词法分析中的文法改写成无左递归和无左共因子的BNF如下: 程序→程序首部分程序。 程序首部→PROGRAM标识符; 分程序→常量说明部分变量说明部分过程说明部分 复合语句 常量说明部分→CONST常量定义常量定义后缀;|ε 常量定义→标识符=无符号整数 常量定义后缀→,常量定义常量定义后缀 |ε 变量说明部分→VAR变量定义变量定义后缀 |ε 变量定义→标识符标识符后缀:类型; 标识符后缀→,标识符标识符后缀 |ε 变量定义后缀→变量定义变量定义后缀 |ε 类型→INTEGER | LONG 过程说明部分→过程首部分程序;过程说明部分后缀|ε 过程首部→PROCEDURE标识符参数部分; 参数部分→(标识符: 类型)|ε 过程说明部分后缀→过程首部分程序;过程说明部分后缀|ε 语句→赋值或调用语句|条件语句|当型循环语句|读语句 |写语句|复合语句|ε 赋值或调用语句→标识符后缀 后缀→:=表达式|(表达式)|ε 条件语句→IF条件THEN语句 当型循环语句→WHILE条件DO 语句 读语句→READ(标识符标识符后缀) 写语句→WRITE(表达式表达式后缀) 表达式后缀→,表过式表达式后缀|ε 复合语句→BEGIN语句语句后缀END 语句后缀→;语句语句后缀|ε 条件→表达式关系运算符表达式|ODD表达式 表达式→+项项后缀|-项项后缀|项项后缀 项后缀→加型运算符项项后缀|ε 项→因子因子后缀 因子后缀→乘型运算符因子因子后缀|e 因子→标识符|无符号整数|(表达式) 加型运算符→+|- 乘型运算型→*|/ 关系运算符→ =|||=||= 程序设计思想 为每个非终结符设计一个识别的子程序,寻找该非终结符也就是调用相应的子程序。由于单词在语法分析中作为一个整体,故在语法识别中仅使用其内码。在这里将词法分析作为语法分析的一个子程序,当语法分析需要单词时,就调用相应的词法分析程序获得一个单词。语法分析的作用是识别输入符号串是否是文法上定义的句子,即判断输入符号串是否是满足“程序”定义的要求。也就是当语法识别程序从正常退出表示输入符号串是正确的“程序”;若从出错退出,则输入符号串不是正确的“程序”。出错时,可以根据读字符的位置判断出错的位置。表2-1为非终结符和函数名对照表。 表2-1 非终符和函数名对照表 非终结符 函数名 非终结符 函数名 程序 program 程序首部 proghead 分程序 block 常量说明部分 consexpl 常量定义 consdefi 变量说明部分 varexl 常量定义后缀 conssuff 变量定义 vandefi 变量定义后缀 varsuff 过程说明部分 procdefi 类型 typeil 过程首部 procedh 过程说明部分后缀 procsuff 赋值或调用语句 assipro 语句 sentence 后缀 suffix 条件语句 ifsent 读语句 read 当型循环语句 whilsent 标识符后缀 idsuff 写语句 write 复合语句 compsent 表达式后缀 exprsuff 语句后缀 sentsuff 条件 conditio 项后缀 termsuff 表达式 express 项 term 因子后缀 factsuff 参数部分 argument 因子 factor 加型运算符 addoper 乘型运算符 muloper 关系运算符 respoper 表2-2为词法分析中的内码单词对照表。 表2-2 内部码对照表 内码 单词 内码 单词 内码

文档评论(0)

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

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

1亿VIP精品文档

相关文档