语法与语义分析详解.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};;2、向前看集 定义:设有文法G=(VT,VN,S,P),非终结符号U的向前看集定义为 Follow(U)={a|S ? …Ua…,a? VTU{#}} #:非终结符号U后面的符号串为空,则将U后的符号记作特殊符号#; Follow(U)={所有含有U的句型中紧跟U之后的终结符}U{#} 例如:文法:G=({i,+,*,(,)},{T,E,F},E,P) ;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)={#,+,*,)};;一、常用的终结符号集(续六);一、常用的终结符号集(续七);二、自顶向下分析;二、自顶向下分析(续一);二、自顶向下分析(续二 );二、自顶向下分析(续二 );二、自顶向下分析(续三 );二、自顶向下分析(续四 );二、自顶向下分析(续五);推导与归约自顶向下与自底向上;推导与归约自顶向下与自底向上;推导与归约自顶向下与自底向上;四、虚拟机;四、虚拟机(续一);五、递归子程序方法;五、递归子程序方法(续一);五、递归子程序方法(续二);六、逆波兰表达式;六、逆波兰表达式(续一);中缀、前缀、后缀表示法功能等价 共同点: 1、运算符的个数不变; 2、运算分量的次序不变; 后缀表示法的好处: a:无括号,形式简洁; b:运算符的顺序与运算的次序完全相同。;六、逆波兰表达式(续二);六、逆波兰表达式(续三);六、逆波兰表达式(续四);开始;六、逆波兰表达式;实例2

文档评论(0)

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

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

1亿VIP精品文档

相关文档