- 1、本文档共22页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第四章 4.1 语法分析器的功能 4.2 自上而下分析面临的问题 4.3 LL(1)分析法 4.4 递归下降分析程序构造 4.5 预测分析程序 4.6 LL(1)分析中的错误处理 4.3 LL(1)分析法 4.3.1 左递归的消除 4.3.2 消除回溯、提左因子 4.3.3 LL(1)分析条件 4.3.4 LL(1)文法的判别 (4.5.2) 4.3.4 LL(1)文法的判别 (4.5.2) 文法中不得含有有害规则和多余规则 消除左递归和提左公因子 求出能 ε的非终结符 (补充) 计算FIRST集 计算FOLLOW集 计算SELECT集 (补充) 1. 求出能推出ε的非终结符 算法描述 建立一个一维数组X[ ],用以记录非终结符能否推出ε。 ① 将数组X[ ]中对应每一非终结符的标记置初值为“未定”。 ② 扫描文法中的产生式。 (a) 若某一非终结符的某一产生式右部为ε, 则将数组中对应该非终结符的标志置为“是”, 并从文法中删除该非终结符的所有产生式。 (b) 若某一产生式右部含有终结符,则删除该产生式。(右部含有终结符,一定无法推出ε) 若这使得以某一非终结符为左部的所有产生式都被删除,则将数组中对应该非终结符的标记值改为否。 ③ 扫描产生式右部的每一符号。 (此时产生式右部全部为非终结符) (a) 若所扫描到的非终结符号在数组中对应的标志是是,则删去该非终结符, 若这使产生式右部为空, 则对产生式左部的非终结符在数组中对应的标志改是,并删除该非终结符为左部的所有产生式。 (b) 若所扫描到的非终结符号在数组中对应的标志是否,则删去该产生式, 若这使产生式左部非终结符的有关产生式都被删去,则把在数组中该非终结符对应的标志改成“否”。 ④ 重复③,直到扫描完一遍文法的产生式,数组中非终结符对应的特征再没有改变为止。 2. 计算FIRST集 对每一文法符号X∈V , 计算FIRST(X) (a) 若X∈VT,则FIRST(X)={X} (b) 若X∈VN,且有产生式 X→ a… , a∈VT , 则 a∈FIRST(X) 即把a加入到FIRSR(X)中 (c) 若X∈VN,且有产生式 X→ε, 则ε∈FIRST(X) (d) 若X∈VN, 且有产生式 X→Y1 Y2 …Yi-1 Yi … Yn, 当Y1 Y2 … Yi-1都能推出ε时, 则 FIRST(Y1)-{ε} FIRST(Y2)-{ε} … FIRST(Yi-1)-{ε} FIRST(Yi) 都包含在FIRST(X)中。 (e) 当(d)中X→Y1 Y2 … Yn 所有Yj 都可以推出ε, (j=1,2,…n) , 则 FIRST(Y1) FIRST(Y2) … FIRST(Yn) 都包含在FIRST(X)中 反复使用上述(b)~(e)步直到每个符号的FIRST集合不再增大为止。 求一个符号串α的FIRST集合 若符号串α∈V*,α=X1 X2 … Xi-1 Xi … Xn, 若X1不能推导出ε, 则 FIRST(α)= FIRST(X1) 若对任何j (1≤j≤i-1, 2≤i≤n) ε∈FIRST(Xj) 若对任何j (1≤j≤n) ε∈FIRST(Xj), 例4.7 文法4.2 求FIRST集 P79 3. 计算FOLLOW集 (a) 设S为文法中开始符号, 把 # 加入FOLLOW(S)中 (b) 若A→αBβ是一个产生式, 则把FIRST(β)\{ε} 加入FOLLOW(B)中 (c) 若A→αB是一个产生式, 或A→αBβ是一个产生式, 且β可推出ε, 即ε∈FIRST(β) , 则把FOLLOW(A)也 加入FOLLOW(B)中。 (d) 反复使用(b)直到每个非终结符的FOLLOW集不再增大为止。 例4.7 文法4.2 求FOLLOW集 P79 例4.7 文法4.2 LL(1)文法判别 P79 G: E →TE E→+TE|ε T →FT T→*FT|ε F →(E) | i FIRST(+TE)∩FIRST(ε)=? FIRST(E)∩FOLLOW(E)=? FIRST(*FT)∩FIRST(ε)=? FIRST(T)∩FOLLOW(T)=? FIRST((E))∩FIRST(i)=? 4. 计算SELECT集 给定上下文无关文法的产生式A→α, A∈VN, α∈V*, 若α ε, SELECT(A→α) = FIRST(α) 若α ε, SELECT(A→α) = (FIRST(α)-{ε})∪
您可能关注的文档
最近下载
- 胰岛素抵抗和代谢综合征课件.pptx VIP
- 胰岛素抵抗和代谢综合征.ppt VIP
- GB/T 17747.1-2011_天然气压缩因子的计算 第1部分:导论和指南.pdf
- 《基础护理学》第7章 休息与活动(含答案).docx
- 城市中心区综合性公园使用现状调查研究————以成都市人民公园为例.docx
- 产品档案管理制度及流程.pdf
- 中华民族一家亲,同心共筑中国梦.pptx VIP
- “社工+志愿者”联动模式的思考及对策研究--以惠州市河背社区志愿者项目为例.docx
- 国家开放大学,地域文化,人文武隆形考一 (3).pptx VIP
- (黑龙江省)新课标高中信息技术会考试题 学科整合 试题及答案..doc VIP
文档评论(0)