




已阅读5页,还剩40页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
3 7分析器的生成器 3 7 1分析器的生成器Yacc Lex编译器 Lex源程序lex l lex yy c C编译器 lex yy c a out a out 输入流 记号序列 用Lex建立词法分析器的步骤 1 36 Yacc程序包括三个部分声明 翻译规则 支持例程 3 7分析器的生成器 例 声明部分 include 常量 变量的声明 tokenDIGIT 3 7分析器的生成器 E E T TT T F FF E digit 例 翻译规则部分line expr n printf d n 1 expr expr term 1 3 term term term factor 1 3 factor factor expr 2 DIGIT 3 7分析器的生成器 E E T TT T F FF E digit 例 支持例程部分yylex intc c getchar if isdigit c yylval c 0 returnDIGIT returnc 3 7分析器的生成器 E E T TT T F FF E digit 5 36 3 7分析器的生成器 3 7 2用Yacc处理二义文法解决分析动作冲突的两大默认规则 对于归约 归约冲突 选择在Yacc程序中最先出现的那个产生式归约对于移进 规约冲突 优先移进 3 7分析器的生成器 3 7 2用Yacc处理二义文法例台式计算器输入一个表达式并回车 显示计算结果 也可以输入一个空白行 lines linesexpr n lines n eE E E E E E E E E E E number 3 7分析器的生成器 include include defineYYSTYPEdouble 将栈定义为double类型 tokenNUMBER left left rightUMINUS lines linesexpr n lines n eE E E E E E E E E E E number 3 7分析器的生成器 lines linesexpr n printf g n 2 lines n expr expr expr 1 3 expr expr 1 3 expr expr 1 3 expr expr 1 3 expr 2 expr precUMINUS 2 NUMBER lines linesexpr n lines n eE E E E E E E E E E E number 3 7分析器的生成器 yylex intc while c getchar if c isdigit c ungetc c stdin scanf lf lines linesexpr n lines n eE E E E E E E E E E E number 10 36 3 7分析器的生成器 3 7 3Yacc的错误恢复编译器设计者的工作决定哪些 主要的 非终结符将有错误恢复与它们相关联加入A error 的错误产生式 其中A是主要非终结符 是文法符号串为这样的产生式配上语义动作Yacc把错误产生式当作普通产生式处理 3 7分析器的生成器 遇到语法错误时从栈中弹出状态 直到发现栈顶状态的项目集包含形为A error 的项目为止把虚构的终结符error 移进 栈若 为 直接进行产生式规约 并执行相关的语义动作 忽略若干输入符号 直至发现能回到正常处理的符号为止 若 不为 找到 把 移进栈把error 归约为A 恢复正常分析 3 7分析器的生成器 lines linesexpr n printf g n 2 lines n error n printf 重新输入上一行 yyerrok 语法分析内容总结 文法和语言的基本知识自上而下的分析方法 预测分析 非递归的预测分析 LL 1 文法自下而上的分析方法 SLR 1 方法 规范LR 1 方法和LALR 1 方法 语法分析内容总结 自上而下分析LL 1 文法判定原则FIRST FOLLOW集的计算 重点 LL 1 文法判定方法LL 1 分析实现方法递归函数实现非递归的预测分析实现先求FIRST FOLLOW集画预测分析表 语法分析内容总结 书后3 19 3 20等题目都是判断是否属于某类文法 判定文法是否是LL 1 文法步骤如下 如果有以下两种情况一定不是左递归公共左因子如果不是 则改写文法消除左递归提取左因子改写后进行LL 1 分析 语法分析内容总结 例1文法G S S aSb PP bPc bQcQ Qa a 1 判断这个文法是不是LL 1 的 2 消除左递归 提取左因子之后的文法G 是否是LL 1 的 语法分析内容总结 解答 首先 G S 不是LL 1 的 G S S aSb PP bPc bQcQ Qa a 语法分析内容总结 例1解答 提取左因子 将P bPc bQc变为P bP P Pc Qc 消除左递归 将Q Qa a变为Q aQ Q aQ G S S aSb PP bPc bQcQ Qa a 语法分析内容总结 例1解答 判定文法G S 是否LL 1 步骤 计算FIRST FOLLOW集 G S S aSb PP bP P Pc QcQ aQ Q aQ 语法分析内容总结 FIRST S a b FIRST P b FIRST P a b FIRST Q a FIRST Q a FOLLOW S b FOLLOW P b c FOLLOW P b c FOLLOW Q c FOLLOW Q c G S S aSb PP bP P Pc QcQ aQ Q aQ 是LL 1 的 语法分析内容总结 例2文法G E E TT TE F F a aF 1 判断这个文法是不是LL 1 的 2 消除左递归 提取左因子之后的文法G 是否是LL 1 的 语法分析内容总结 例1解答 提取左因子 消除左递归后文法变为G E E TT F T T ET F aF F F G S E TT TE F F a aF 语法分析内容总结 FIRST E FIRST T a FIRST T FIRST F a FIRST F a FOLLOW E FOLLOW T FOLLOW T FOLLOW F FOLLOW F G E E TT F T T ET F aF F F 不是LL 1 文法 通过提取左因子和消除左递归的方法 并不一定能够把文法改写为一个LL 1 文法 语法分析内容总结 左递归的消除G S S Qc cQ Sa a间接左递归 语法分析内容总结 左递归的消除G S S Qc cQ Sa a这是一类间接左递归S Sac ac cQ Sa a 语法分析内容总结 左递归的消除G S S Qc cQ Sa a间接左递归S Sac ac cQ Sa aS acS cS S acS Q Sa a 语法分析内容总结 自下而上分析部分知识点SLR的DFA的构造及分析表的构成初始项目集合的产生 拓广文法 能够识别同一符号的项目都转移到同一集合中求闭包过程中每一个 后面的非终结符都要重新考虑是否已经在状态中列出对产生式A 规约 ri 写在FOLLOW A 集合中元素对应的位置 语法分析内容总结 LR LALR的构造方法 在SLR的基础上加上搜索符 搜索符的求法 根据造成目前项目出现的那个父项目来求 求闭包的过程中可能出现要添加的项目已经存在 但是搜索符不同的情况 相当于其父项目已经改变 此时需要再求一遍搜索符 SLR LR LALR的区别及判别方法通过构造DFA 看其中的状态是否有冲突 移进 规约 或 规约 规约 若有冲突则不属于该文法类型 通过构造分析表 看其中某项是否有冲突 语法分析内容总结 文法G S S AaS bAe BeS bBaA dB d判断这个文法类型是SLR 1 LR 1 还是LALR 1 补充题1 下面的二义文法描述命题演算公式的语法 为它写一个等价的非二义文法S SandS SorS notS p q S 非二义文法的产生式如下 E EorT TT TandF FF notF E p q 补充题1 下面的二义文法描述命题演算公式的语法 为它写一个等价的非二义文法S SandS SorS notS p q S 非二义文法的产生式如下 E EorT TT TandF FF notE E p q 补充题1 下面的二义文法描述命题演算公式的语法 为它写一个等价的非二义文法S SandS SorS notS p q S 非二义文法的产生式如下 E EorT TT TandF FF notE E p qnotpandq有两种不同的最左推导 补充题2 设计一个文法 字母表 a b 上a和b的个数相等的所有串的集合二义文法 S aSbS bSaS aabbababaabbabab 补充题2 设计一个文法 字母表 a b 上a和b的个数相等的所有串的集合二义文法 S aSbS bSaS aabbababaabbabab二义文法 S aB bA A aS bAAB bS aBBaabbababaabbabab 补充题2 设计一个文法 字母表 a b 上a和b的个数相等的所有串的集合二义文法 S aSbS bSaS abababab二义文法 S aB bA A aS bAAB bS aBBBB bSbS的选择bbabbbab非二义文法 S aBS bAS A a bAAaabbababB b aBB 补充题3 试说明下面文法不是LR 1 的 L MLb aM 补充题4 下面的文法不是LR 1 的 对它略做修改 使之成为一个等价的SLR 1 文法program begindeclist statementenddeclist d declist dstatement s statement s 补充题4 下面的文法不是LR 1 的 对它略做修改 使之成为一个等价的SLR 1 文法program begindeclist statementenddeclist d declist dstatement s statement s该文法产生的句子的形式是begind d d s s send 补充题4 下面的文法不是LR 1 的 对它略做修改 使之成为一个等价的SLR 1 文法program begindeclist statementenddeclist d declist dstatement s statement s该文法产生的句子的形式是begind d d s s send当d在栈顶 是下一个输入的时候不知该移进还是规约 补充题4 下面的文法不是LR 1 的 对它略做修改 使之成为一个等价的SLR 1 文法program begindeclist statementenddeclist d declist dstatement s statement s该文法产生的句子的形式是begind d d s s send修改后的文法如下 program begindecliststatementenddeclist d declist d statement s statement s 补充题5 一个C语言的文件如下 第四行的if误写成fi longgcd p q longp q fi p q 0 returnq elsereturngcd q p q 基于LALR 1 方法的一个编译器的报错情况如下 parseerrorbefore return line5 是否违反了LR分析的活前缀性质 第三次上机 简易可视化非所见即所得的编辑器 类似latex的简单编辑器 允许输入上标 下标 括号等文本编辑 多行文本的编辑排版 知识点 编译原理中的词法分析 语法分析 翻译方
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- (2025年标准)股份转卖协议书
- (2025年标准)购置门面协议书
- 2026届四川省外国语学校高三化学第一学期期末预测试题含解析
- 系统架构设计研究-洞察及研究
- 2026届安徽省黄山市屯溪三中高二化学第一学期期中学业质量监测模拟试题含解析
- 饲料生物强化技术-洞察及研究
- 2025年新个人贷款契约协议书
- 聚合物纳米粒子吸附水体磷-洞察及研究
- 2025年新场内施工安全协议书
- 2025年物流司机送货协议书
- 人教PEP版(2024)新四年级上册 教材解读
- 纪念中国人民抗日战争暨世界反法西斯战争胜利80周年
- 2025四川省高级人民法院招聘聘用制审判辅助人员30人考试备考题库及答案解析
- 加气块砌筑知识培训课件
- 智慧养老服务与管理课件
- 2025年湖南安全技术职业学院招聘考试笔试试题(含答案)
- 配电带电作业工考试试卷与答案
- 2025年河南省机关事业单位工勤技能岗位等级考试(兽医防治员·高级技师/一级)(综合评审技能)历年参考题库含答案详解(5卷)
- 2025年职业技能鉴定考试(地勘钻探工)历年参考题库含答案详解(5套)
- 保密教育培训课件内容
- 陕西省专业技术人员继续教育2025公需课《党的二十届三中全会精神解读与高质量发展》20学时题库及答案
评论
0/150
提交评论