为什么终结符只有综合属性?

妖狐艹你老母 2022-12-23 03:26 134阅读 0赞

书本上关于综合属性与继承属性的定义是:

  1. 对关联产生式A-> α \alpha α的语义动作b:=f(c1,c2,c3,…,ck),如果b是A的某个属性,则称b是A的一个综合属性。从分析树的角度来看,计算综合属性是对父结点的属性赋值,所以是自底向上传递信息。
  2. 对关联产生式A-> α \alpha α的语义动作b:=f(c1,c2,c3,…,ck),如果b是产生式右部某个文法符号X的某个属性,则称b是文法符号X的一个继承属性。从分析树的角度来看,计算继承属性是对子结点的属性赋值,所以是自顶向下传递信息。

那么从字面意思理解,b是A的某个属性,那么非终结符肯定有综合属性了;而终结符是不可能出现在产生式左边的,所以终结符是没有综合属性的;X在产生式右部,X可能是终结符,所以终结符是有继承属性的。

从另一个角度理解:综合属性用于自底向上传递信息,一个结点的综合属性应该是由它的子结点决定,但是在语法树中终结符是没有子结点的,所以终结符不该有综合属性只能有继承属性。

查遍了网上的所有资料,只有这么一句话:终结符只有综合属性,它由词法分析器提供。

这样理解:两种属性的定义是从语法树的角度来说的。如果某个属性是它的子结点属性计算得到的,那么这个属性就是综合属性;如果某个属性是它的父结点或其兄弟结点计算得到的,那么这个属性就是继承属性。特殊情况是终结符的属性都是由词法分析器提供的,也叫做内在属性,被认为是综合属性,这是定义的特例

发表评论

表情:
评论列表 (有 0 条评论,134人围观)

还没有评论,来说两句吧...

相关阅读

    相关 面试官:Java为什么值传递?

    面试官爱问的一个基础问题:Java是值传递还是引用传递? 想必大家都对这个问题都有自己的看法,那到底事实是怎样的,我们又该如何回答面试官这个问题呢?今天咱们就来好好分析一波

    相关 为什么说Java中值传递

    对于初学者来说,要想把这个问题回答正确,是比较难的。在第二天整理答案的时候,我发现我竟然无法通过简单的语言把这个事情描述的很容易理解,遗憾的是,我也没有在网上找到哪篇文章可以把

    相关 为什么JAVA单继承

    首先我们要明确一个事实,在Java语言中类只能单继承与某个类,却可以多集成接口。同时接口与接口之间可以多继承。 为什么Java类只能单继承? “Java是一种简单的,面...