- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(四) 语法与语义分析 一、常用的终结符号集 一、常用的终结符号集(续一) 1、首符号集 定义:设有文法G=(VT,VN,S,P),字汇表为V,则符号串?的首符号集定义为 First(?)={?|? ? ?y, ?? VT , y ? V*} 特别,若?为空串?,则有 First( ? )= ? 例如:文法:G=({i,+,*,(,)},{T,E,F},E,P) 一、常用的终结符号集(续二) P: E::=E+T|T T::=T*F|F F::=i|(E) 则 First(E)={i,(}; First(T*F)={I,(}; First((i))={(}; First(i+i)={i}; 一、常用的终结符号集(续四) P: E::=E+T|T T::=T*F|F F::=i|(E) 则因: E E; E E+T; E (E) Follow(E)={#,+,)}; 一、常用的终结符号集(续五) P: E::=E+T|T T::=T*F|F F::=i|(E) 则因: E F; E T*F +T; E F*F; E (F) Follow(E)={#,+,*,)}; 一、常用的终结符号集(续六) 3、可选集 定义:设有文法G=(VT,VN,S,P),规则P中 A=::a,则该规则的可选集定义为: 一、常用的终结符号集(续七) 例如:文法:G=(a,b,c,d, ?},{S,B},S,P)其中 P: S=::aBc|bB B=::bB|d| ? 二、自顶向下分析 自顶向下分析的思路: 对于文法 G=(VT,VN,S,P),待分析的句子 (符号串)a,分析思路就是从 S出发,试图推导出符号串 a. 从推导角度看,分析思路即为从文法的开始符开 始根据规则试图建立一个推导序列,若得到所给 的字符串则字符串得到识别,其结构符合文法, 否则不符合文法。(参见第二章) 二、自顶向下分析(续一) 例:文法:G=({i,+,-,/,*,(,)},{T,E,F},E,P) P: E::=T|E+T|E-T (1) T::=F|T*F|T/F (2) F::=i|(E) (3) 分析句子(i+i)-i是否符合文法: 二、自顶向下分析(续二 ) 自顶向下分析的难点: 如果规则中含有一条或者多条类似(1)的规则,则在推导过程中很难确定到底选用那一条规则,如果采用遍历全部规则的方法则最明显的缺点就是效率低。 E::=T1| T2 | T3 | T4 | …...| Tn (1) 二、自顶向下分析(续二 ) 难点解决: 候选式: 如有规则A::=T1| T2 | T3 | T4 | …...| Tn ,则Ti称为A的后选式。 思路:通过当前的输入字符a来决定对后选式的选择。 二、自顶向下分析(续三 ) 3、如果非终结符有n个后选式,即A::=T1| T2 | T3 | T4 | …...| Tn ,则要分(I)(II)两种情况: (I)首符号不相同 对于文法中有规则A::=T1| T2 | T3 | T4 | …...| Tn ,若n个后选 式的首符号均不相同即First(Ti)? First(Tj)= ?(i?j) 对于待分析的符号串,如果其第一个符号(即当前的输入 符号)为a,且有a? First(Tk),则选择规则A::= Tk进行推导, 即选择后选式Tk。 二、自顶向下分析(续四 ) (II)首符号相同 对于文法中有规则A::=T1| T2 | T3 | T4 | …...| Tn ,若 First(Ti)? First(Tj) ? ? (i?j) a:试探法——回溯现象 b:左提左因子法修改文法,将问题转化到(I) 二、自顶向下分析(续五) 例:文法:G=({a,b,x},{Z,V},Z,P) P: Z::=aV|bZ (1) V::=baZ|x (2) 待分析符号串:bbabaax. 自顶向下分析: 推导与归约自顶向下与自底向上 直接推导、直接归约、推导、归约 直接推导:设有文法G=(VT,VN,S,P),?,?? (VT ? VN)*,如果有A——〉??P,则称?A?直接推导出???,即: ?A? ???? 其中‘?’表示直接推导。 可以称?A?直接推导出???,或者??? 是?A?的直接推导。 与推导方向相反,称???直接归约到?A?记作: ?????A? 推导与归约自顶向下与自底向上 推导与归约自顶向下与自底向上 四、虚拟机 虚拟机:虚拟机不是一台实际的机器,而是为了便于讨论的一台假设和抽象的计算
您可能关注的文档
最近下载
- 湖南省自然科学基金学科分类目录及代码.pdf VIP
- 人教版三年级上册道德与法治教学计划.docx VIP
- 检验检测机构资质认定评审准则培训考试卷(附答案).docx VIP
- 事业单位内部控制操作手册.pdf VIP
- DB32T 4611-2023 建设用地地下水污染修复和风险管控技术导则.pdf VIP
- 8.煮面条(课件) 教学课件.ppt VIP
- 《新媒体技术:基础 案例 应用》课件 项目5 使用自媒体工具.pptx VIP
- 2025年济南市中考语文试题卷(含答案解析).docx
- 第2课 第二次鸦片战争 课件(26张PPT).pptx VIP
- 项贤明主编马工程教材《教育学原理》第九章教师与学生.ppt VIP
文档评论(0)