第六.七章总结

程序设计语言——编译原理 第六、七章总结
第六章

属性文法是在上下文无关文法的基础上为每个文法符号(终结符或非终结符)配备若干个相关的“值”(称为属性)。

属性代表与文法符号相关的信息,和变量一样,可以进行计算和传递。(例:类型、值、代码序列、符号表内容等)属性通常分为两类:综合属性(自下而上传递信息)和继承属性(自上而下传递信息)。注意,终结符只有综合属性,非终结符既有综合也有继承。

语义规则:属性计算的过程即是语义处理的过程,对于文法的每一个产生式配备一组属性的计算规则,则称为语义规则。包括属性计算、静态语义检查、符号操作、代码生成等。

考虑非终结符A,B和C,其中,A有一个继承属性a和一个综合属性e,B有综合属性b,C有继承属性c。

         产生式     A → BC 应该有计算c和e的规则

         C.c := B.b + 1

         A.e := A.a + B.b

         其中属性A.a和B.b在其他地方计算。

 从概念上讲,基于属性文法的处理过程通常如下:

  输入串®语法树®依赖图®语义规则计算次序®计算结果

这种由源程序的语法结构所驱动的处理办法就是语法制导翻译法。

在一棵语法树中的节点的继承属性和综合属性之间的相互依赖关系可以由称作依赖图的有向图来表示。注:b依赖于c表示为 c→b。

良义文法是指属性文法不存在属性之间的循环依赖关系。

假设语法树已经建立起了,并且树中已带有开始符号的继承属性和终结符的综合属性。然后以某种次序遍历语法树,直至计算出所有的属性。最常用的遍历方法是深度优先,从左到右的遍历方法,如果需要,可使用多次遍历。

与树遍历的属性计算方法不同,一遍扫描的处理方法是在语法分析的同时计算属性值,而不是语法分析构造语法树之后进行属性的计算,而且无需构造实际的语法树。

从语法树中去掉对翻译不必要的信息,而获得更有效的源程序中间表示。这种经变换后的语法树称之为抽象语法树。在抽象语法树中,操作符和关键字都不作为叶结点出现,而是把它们作为内部结点,即这些叶结点的父结点。

建立表达式的语法树使用的函数

    

2.属性分类

属性代表与文法符号相关信息(例如其类型,值,代码序列……)

属性分为综合属性与继承属性

综合属性

①用于“自下而上”传递信息

②在语法树中,一个结点的综合属性的值,由其子结点的属性值确定

继承属性

①用于“自上而下”传递信息。

②在语法树中,一个结点的继承属性由此结点的父结点和/或兄弟结点的某些属性确定

3.语义规则

属性计算的过程即是语义处理的过程

对于文法的每一个产生式配备一组属性的计算规则,则称为语义规则

在一个属性文法中,对应于每个产生式A都有一套与之相关联的语义规则,每条语义规则的形式为:

b:=f(c1,c2,…,ck)  

这里f是一个函数,而且或者

(1)b是A的一个综合属性并且c1,c2,…ck是产生式右边文法符号的属性;或者

(2)b是产生式右边某个文法符号的一个继承属性并且c1,c2,…ck是A或产生式右边任何文法符号的属性在这两种情况下,我们都说属性b依赖于属性c1,c2,…,ck.

①终结符只有综合属性,它由词法分析器提供

②非终结符既可以有综合属性也可以有继承属性,文法开始符号的所有继承属性作为属性计算前的初始值

③ 产生式右边符号的继承属性和产生式左边符号的综合属性都必须提供一个计算规则

④产生式左边符号的继承属性和产生式右边符号的综合属性不由所给的产生式的属性计算规则进行计算,它们由其它产生式的属性规则计算

4.  语法制导翻译法:这种由源程序的语法结构所驱动的处理办法就是语法制导翻译法

5.依赖图

在一颗语法树中的结点的继承属性和综合属性之间的相互依赖关系可以用称作依赖图的一个有向图来描述

如果在一棵语法树中一个结点的属性b依赖于属性c,那么这个结点处计算b的属性规则必须在确定c的语义规则之后使用

在为一棵语法树构造依赖图以前,我们为每一个包含过程调用的语义规则引入一个虚综合属性b,这样把每一个语义规则都写成

b:= f(c1,c2, …ck)依赖图中为每一个属性设置一个结点,如果属性b依赖属性c,则从属性c的结点有一条有向边连到属性b的结点

6.依赖图的构造算法

for分析树中每一个结点n

          for 结点的文法符号的每一个属性a

                    为a在依赖图中建立一个结点;


for分析树中每一个结点n

                  for结点n所用产生式对应的每一个语义规则

b:=f(c1,c2,…ck)

                                 for i :=1 to k

从ci结点到b结点构造一条有向边

7.如果一属性文法不存在属性之间的循环依赖关系,那么该文法为良定义的。为了设计编译程序,我们只处理良定义的属性文法

8.属性的计算次序

 一个有向非循环图的拓扑序是图中结点的任何顺序m1,m2, …mk,使得边必须是从序列中前面的结点指向后面的结点。也就是

说,如果mi→mj是mi到mj的一条边,那么在序列中mi必须出现在mj之前

一个依赖图的任何拓扑排序都给出一个语法树中结点的语义规则计算的有效顺序。这就是说,在拓扑排序中,在一个结点上,语

义规则b:=f(c1,c2,…ck)中的属性c1,c2…ck在计算b以前都是可用的

9. S属性的自下而上计算

S—属性文法,它只含有综合属性

综合属性可以在分析符号串的同时由自上而下的分析器来构造

分析器可以保存与栈中文法符号有关的综合属性值

每当进行归约时,新的属性值就由栈中正在归约的产生式右边符号的属性值来计算

可以通过扩充分析器中的栈来存放这些综合属性值

S-属性文法的翻译器通常可借助于LR分析器实现

10.L-属性文法的自顶向下翻译     

L-属性文法

如果每个产生式A →X1 X2 … Xn 的每条语义规则计算的属性是A的综合属性;或者是Xj 的继承属性, 1 ≦j ≦ n, 但它仅依赖:该

产生式中Xj左边符号X1, X2, …, Xj-1的属性;A的继承属性

11. 翻译模式

翻译模式是语法制导定义的一种便于翻译的书写形式。其中属性与文法符号相对应,语义规则或语义动作用花括号{ }括起来,

可被插入到产生式右部的任何合适的位置上

这是一种语法分析和语义动作交错的表示法,他表达在按深度优先遍历分析树的过程中何时执行语义动作

翻译模式给出了使用语义规则进行计算的顺序。可看成是分析过程中翻译的注释

12.设计翻译模式(根据语法制导定义)

条件:语法制导定义是L-属性定义

保证语义动作不会引用还没有计算的属性值

(1)只需要综合属性的情况

为每一个语义规则建立一个包含赋值的动作,并把这个动作放在相应的产生式右边的末尾

(2)既有综合属性又有继承属性     

①产生式右边的符号的继承属性必须在这个符号以前的动作中计算出来

②一个动作不能引用这个动作右边符号的综合属性

③产生式左边非终结符号的综合属性只有在它所引用的所有属性都计算出来以后才能计算。计算这种属性的动作通常可放在产生

式右端的未尾
第七章

     

中间代码生成:把经过语法分析和语义分析而获得的源程序中间表示翻译为中间代码表示。

方法:语法制导翻译

好处:1. 便于编译系统建立和编译系统的移植;2. 便于进行独立于机器的代码优化工作。

 

中间表示形式:中间表示形式通常是一个图形表示方法和三地址代码的组合。比如在语法树中,图中的结点表示一个程序的构造;而各个子结点表示其子构造。三地址代码每条指令之多有一个运算符。另外还有一些用于控制流的三地址

三地址语句的种类:

(1)     赋值语句 x:=y op z,op为二目算术算符或逻辑算符;

(2)     赋值语句 x:=op y ,op为一目算符,如一目减uminus、逻辑非not、移位算符及转换算符;

(3)     无条件转移语句goto L;

(4)     条件转移语句 if x relop y goto L,关系运算符号relop(< ,=,>= 等等);

(5)     复制语句  x:=y;

(6)     过程调用语句 param x 和 call p, n ;

          过程返回语句 returny;

(7)     索引赋值 x:=y[i] 及 x[i] :=y ;

(8)     地址和指针赋值 x=&y,x=* y

        和  * x=y。

 

1.四元式  op, arg1, arg2, result

2.三元式 op, arg1, arg2

3.间接三元式  间接码表+三元式表

 


   

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值