递归下降语法分析设计原理与实现关键技术实验报告.docVIP

递归下降语法分析设计原理与实现关键技术实验报告.doc

  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文档。上传文档
查看更多
递归下降语法分析设计原理和实现技术 试验汇报 变更说明 日期 版本 变更位置 变更说明 作者 20XX/4/16 1.0 初稿生成 房皓 试验目标: 本试验目标在于在老师引导下以问题回朔和思维启发方法,使学生在不停探究过程中掌握编译程序设计和结构基础原理和实现技术,启迪学生抽象思维、激发学生学习爱好、培养学生探究精神和专业素养,从而提升学生发觉问题、分析问题和处理问题能力。 试验内容: [试验项目] 完成以下描述算术表示式LL(1)文法递归下降分析程序 G[E]: E→TE′ E′→ATE′|ε T→FT′ T′→MFT′|ε F→ (E)|i A→+|- M→*|/ [设计说明] 终止符号i 为用户定义简单变量,即标识符定义。 [设计要求] (1)输入串应是词法分析输出二元式序列,即某算术表示式“试验项目一”输出结果,输出为输入串是否为该文法定义算术表示式判定结果; (2)递归下降分析程序应能发觉输入串犯错; (3)设计两个测试用例(尽可能完备,正确和犯错),并给出测试结果。 试验环境: 操作系统:Windows 7 软件: VC++6.0 程序功效描述: 提供了两种输入方法:键盘和文件,有文件输入时需为二元式序列; 能够对输入字符串做出正确递归下降分析判定,并给出判定结果; 能发觉输入串中错误,包含非法字符,输入不匹配等; 能够处理部分可预见性错误,如文件不存在,用户输入非法等。 五、数据结构设计: 全局: 局部(main()中): 六、程序结构描述: 设计方法: 本程序采取从键盘输入或文件读取两种输入方法,其汉字件内容需为二元式序列,然后根据递归下降分析方法对输入字符串进行分析判定,并输出判定结果,程序经过对输入串检验能够发觉输入串中错误。程序要求单词符号及其种别码见下表: 单词符号及其种别码表 单词符号 种别码 单词符号 种别码 ( 1 * 5 ) 2 / 6 + 3 i 7 - 4 # 8 关键函数说明: advance():将下一个字符送入current; error():输犯错误,表示不是该文法句子; error1();输犯错误,输入内容不正当; init():初始化函数; justify():判定文件读取内容是否正当,包含检验非法字符和不匹配现象 main():主函数 函数调用关系说明: main()调用justify()、init()、E()、error1(); justify()调用error1(); A()、E()、E1()、F()、M()、F()、T()、T1()依据输入串可相互调用或递归调用,这些函数均可调用error()函数; A()、F()、M()调用advance()函数。 实施框图: 总体结构图: 2)递归下降分析构框图: E(): E1(): T(): T()1: M(): A(): F(): 试验过程结果截图: 测试用例一:i+i*i/i# 键盘: 文件: 测试用例二:i+i*i/# 键盘: 文件: 试验总结: 试验心得: 经过此次试验我锻炼了自己上机操作能力及编程能力,并对理论知识有了深入了解。老师提供相对应于非终止符号函数步骤图给了我很大帮助,使得本试验基础思绪变得很清楚,用较为简单算法就能实现;处理试验中碰到问题也花费了一部分时间,我增加了处理相关文件错误能力; 试验中碰到问题: 问题关键有在调用某个函数时没有在之前申明或定义过此函数;还有在当用户输入选择方法非法时,提醒错误并要求重新输入,这用一个while循环实现。 程序自我评价: 此程序实现了要求中全部功效,并增加了对用户操作错误、输入串错误检测功效,但因编程能力欠缺,其中有地方不免有些繁杂,还有部分潜藏问题,需要深入测试来时程序变得愈加含有健壮性。 程序清单: /**************************************************** 课题名称:递归下降语法分析设计原理和实现技术 作者:房皓 进修生最终修改时间:20XX.4.16 13:52 ***************************************************/ /**************************************************单词符号及其分类编码 单词符号 种别码 ( 1 ) 2 + 3 - 4 * 5 / 6 i 7 # 8 //////////////////////////////////////////////////文法 G[E]: E →TE′ E′→ATE′|ε T →FT′ T′→MFT′|ε F →(E)|i A →+|- M →*|/

文档评论(0)

159****1748 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档