语法与语义分析资料.ppt

  1. 1、本文档共34页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话: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? 推导与归约自顶向下与自底向上 推导与归约自顶向下与自底向上 四、虚拟机 虚拟机:虚拟机不是一台实际的机器,而是为了便于讨论的一台假设和抽象的计算

文档评论(0)

cc880559 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档