程序设计语言与编译ppt课件_8.1 语义分析概述.pptxVIP

程序设计语言与编译ppt课件_8.1 语义分析概述.pptx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

第八章语义分析;语义检查

一致性检查(类型是否一致);越界检查(数组维数是否正确)。

语义处理

对说明语句,将信息登记在符号表中;对执行语句,生成中间代码。;语法分析只能判断一个句子是否合法,不能给出句子的含义。

句子的含义是通过语义分析体现出来的。

例如:文法G

E→E+E|E–E|E*E|E/E|i

对表达式1+2的分析过程:

;仅语法分析:

结合语义分析后:

;赋予每个文法符号以各种不同的值,这些值称为语义值。

表示形式:X.Y

其中,X为文法符号,Y为语义值的名称。

例如: i.type表示符号i的type语义值

i.VAL表示符号i的VAL语义值

L.Address表示符号L的Address语义值

……

;语义动作

每当用一个产生式进行归约时,需要执行相应的动作对语义值进行操作,这些动作称为语义动作。

语义子程序

每个产生式对应一个语义子程序,负责完成相应的语义动作。每当用一个产生式进行匹配或归约时,相应的语义子程序被调用,完成相应的语义动作。;例子:文法G的产生式和语义子程序

E→E1+E2{E.VAL=E1.VAL+E2.VAL}

E→i{E.VAL=i.VAL}

分析输入串1+2时,语义分析与语法分析同步进行,由语法分析判断输入串是否合法,由语义分析计算它的值:;整数类型语义值(expression.y+expression.l)

其它类型语义值(assignment.y+assignment.l)

文档评论(0)

Kaiser + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档