程序设计语言编译原理第三版第7章-课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《程序设计语言编译原理第三版第7章-课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计语言 编译 原理 第三 课件
- 资源描述:
-
1、1第七章语义分析和中间代码产生第七章语义分析和中间代码产生优化器优化器语法分析器语法分析器静态检查器静态检查器中间代码产生器中间代码产生器中间代码中间代码 一般情况下,在词法分析程序和语法分析程序对源程序的语法结一般情况下,在词法分析程序和语法分析程序对源程序的语法结构进行分析之后,构进行分析之后,要么要么,由语法分析程序直接调用相应的语义子程序进行语义处理;,由语法分析程序直接调用相应的语义子程序进行语义处理;要么要么,首先生成语法树或该结构的某种表示,再进行语义处理。,首先生成语法树或该结构的某种表示,再进行语义处理。2语义处理分两步:语义处理分两步:1.1.静态语义分析,即验证语法结构合
2、法的程序是否真正有意义。静态语义分析,即验证语法结构合法的程序是否真正有意义。2.2.若静态语义正确,语义处理则要执行真正的翻译。若静态语义正确,语义处理则要执行真正的翻译。即即要么要么生成程序的一种中间表示形式(中间代码),生成程序的一种中间表示形式(中间代码),要么要么生成实际的目标代码。生成实际的目标代码。静态语义检查包括:静态语义检查包括:(1 1)类型检查;)类型检查;(2 2)控制流检查;)控制流检查;(3 3)一致性检查;)一致性检查;(4 4)相关名字检查。)相关名字检查。第七章语义分析和中间代码产生第七章语义分析和中间代码产生3中间代码:中间代码:即中间语言,独立于机器的,复
3、杂性介于源即中间语言,独立于机器的,复杂性介于源语言和机器语言之间的一种表示形式。语言和机器语言之间的一种表示形式。采用中间语言的好处:采用中间语言的好处:第七章语义分析和中间代码产生第七章语义分析和中间代码产生(1 1)便于进行与机器无关的代码优化工作;)便于进行与机器无关的代码优化工作;(2 2)使编译程序改变目标机更容易;)使编译程序改变目标机更容易;(3 3)使编译程序的结构在逻辑上更为简单明确。)使编译程序的结构在逻辑上更为简单明确。4 7.1 7.1 中间语言中间语言 7.2 7.2 说明语句说明语句 7.3 7.3 赋值语句的翻译赋值语句的翻译 7.4 7.4 布尔表达式的翻译布
4、尔表达式的翻译 7.5 7.5 控制语句的翻译控制语句的翻译 7.6 7.6 过程调用的处理(略)过程调用的处理(略)7.7 7.7 类型检查类型检查 (略)(略)第七章语义分析和中间代码产生第七章语义分析和中间代码产生57.7.中间语言中间语言中间语言形式:中间语言形式:后缀式三地址代码 图表示法三元式三元式 四元式四元式 间接三元式间接三元式DAGDAG抽象语法树抽象语法树6一、后缀式一、后缀式逆波兰式:逆波兰式:规则规则:7.7.中间语言中间语言(1)E(1)E常量变量:常量变量:后缀式为后缀式为E E本身本身(2)E(2)EE E1 1 op E op E2 2:E E1 1 E E2
5、 2 op(3)E(3)E(E(E1 1):(E(E1 1)(4)E(4)Eop Eop E1 1:E E1 1 op op77.7.中间语言中间语言例子:例子:a a*(b+c)(b+c)(a+b)(a+b)*(c+d)(c+d)abc+abc+*x+yza0(8+z)3x+yza0(8+z)3ab+cd+ab+cd+*xy+za08z+3xy+za08z+38二、图表示法二、图表示法1.DAG(1.DAG(无循环有向图无循环有向图)与抽象语法树对比与抽象语法树对比 相同点相同点:对表达式中的每个子表达式,它们都有一个结对表达式中的每个子表达式,它们都有一个结 点,一个内部结点代表一个操作符
6、,它的孩子点,一个内部结点代表一个操作符,它的孩子 代表操作数;代表操作数;不同点不同点:在一个在一个DAGDAG中代表公共子表达式的结点具有多个中代表公共子表达式的结点具有多个 父结点,而在一棵抽象语法树中公共子表达式父结点,而在一棵抽象语法树中公共子表达式 被表示为重复的子树。被表示为重复的子树。7.7.中间语言中间语言9例子:例子:如图所示,为如图所示,为a+aa+a*(b-c)+(b-c)(b-c)+(b-c)*d d的的DAGDAG +*d a-b c7.7.中间语言中间语言102.2.抽象语法树抽象语法树例子:例子:(1)a:=b*-c+b*-c的图表示法的图表示法assign a
7、+*b uminus b uminus c c语法树语法树assign a+*b uminus cDAGDAG7.7.中间语言中间语言11(2)a:=b*-c+b*-c 的抽象语法树的两种表示法的抽象语法树的两种表示法assignida +*idbuminusidc *uminusidcidbidbIdcuminus1*02idbidcuminus5*46+37idaassign980123456789107.7.中间语言中间语言12三、三地址代码三、三地址代码1.1.三地址代码三地址代码:下面一般形式的语句构成的序列下面一般形式的语句构成的序列:x:=y op zx:=y op zT T1
8、1:=y:=y*z,Tz,T2 2:=x+T:=x+T1 1称为三地址代码的原因称为三地址代码的原因:每条语句通常包含三个地址每条语句通常包含三个地址,两个用来表示操作数两个用来表示操作数,一一个用来存放结果。个用来存放结果。7.7.中间语言中间语言具体实现具体实现:用记录表示用记录表示,其中包含其中包含运算符运算符和和操作数操作数的域。的域。x,y,z:x,y,z:名字名字,常数常数,编译时产生的临时变量编译时产生的临时变量 op:op:运算符号运算符号(如定点运算符如定点运算符,浮点运算符浮点运算符,逻辑运算符等逻辑运算符等)132.2.四元式:四元式:带有四个域的记录结构带有四个域的记录
9、结构 内容均是指针内容均是指针,指向有关名字的符号表入口指向有关名字的符号表入口7.7.中间语言中间语言(op(op,arg1arg1,arg2arg2,result)result)147.7.中间语言中间语言例子例子:三地址语句三地址语句a:=ba:=b*-c+b-c+b*-c-c的四元式表示的四元式表示 四元式表示四元式表示Oparg1arg2result(0)(1)(2)(3)(4)(5)uminus*uminus*+:=cbcbT1T2T1T3T4T1T2T3T4T5a153.3.三元式:三元式:为了避免把临时变量填入符号表为了避免把临时变量填入符号表,可通过计算该临可通过计算该临时变
10、量值的语句的位置来引用该临时变量。时变量值的语句的位置来引用该临时变量。或是指向符号表的指针或是指向符号表的指针对程序中的名字而言对程序中的名字而言或是指向三元式表的指针或是指向三元式表的指针对临时变量而言对临时变量而言7.7.中间语言中间语言(op,arg1,arg2)16oparg1arg2(0)(1)(2)(3)(4)(5)uminus*umins*+assigncbcb(1)a(0)(2)(3)(4)7.7.中间语言中间语言例子例子:三地址语句三地址语句a:=b*-c+b*-c的三元式表示的三元式表示 174.4.间接三元式:间接三元式:便于代码优化处理便于代码优化处理方法:方法:间接
11、码表间接码表+三元式表三元式表按运算的先后顺序列出有关三元式在三元表中的位置按运算的先后顺序列出有关三元式在三元表中的位置oparg1arg2(1)(2)(3)(4)(5)+*:=:=A(1)XDYBC(2)(1)(1)例例:语句语句X:=(A+B)X:=(A+B)*C;Y:=D(A+B)C;Y:=D(A+B)的间接三元式表示如下所示的间接三元式表示如下所示:间接代码间接代码(1)(1)(2)(2)(3)(3)(1)(1)(4)(4)(5)(5)三元式表三元式表7.7.中间语言中间语言187.2 7.2 说明语句说明语句编译过程中编译过程中,对对“说明语句说明语句”要做的工作要做的工作:对一个
12、过程或分程序的一系列说明语句对一个过程或分程序的一系列说明语句,考察时考察时:(1)(1)需要需要为局部于该过程的名字分配存储空间为局部于该过程的名字分配存储空间;(2)(2)对每个局部名字对每个局部名字,都都需在符号表中建立相应的表项需在符号表中建立相应的表项,并填入有关的信息并填入有关的信息如类型、在存储器中的相对地址如类型、在存储器中的相对地址 等。等。19一、过程中的说明语句一、过程中的说明语句1.1.产生产生“说明语句说明语句”的文法:的文法:PDDD;DDid:T TintegerTrealTarraynum of T1TT17.2 7.2 说明语句说明语句202.处理方式:处理方
13、式:处理第一条说明语句处理第一条说明语句之前之前,先置,先置offset为为0 0,以后每次,以后每次遇到一个遇到一个新的名字新的名字,则,则:(1)(1)将该名字填入符号表中将该名字填入符号表中,(2)(2)置相对地址为当前置相对地址为当前offset之值之值,(3)(3)使使offset加上该名字所表示的数据对象的域宽加上该名字所表示的数据对象的域宽。7.2 7.2 说明语句说明语句213.相应的翻译模式:相应的翻译模式:7.2 说明语句说明语句PDDD;DDid:T TintegerTrealTarraynum of T1TT1 offset:=0 enter(id.name,T.typ
14、e,offset);offset:=offset+t.width T.type:=integer;T.width:=4 T.type:=real;T.width:=8 T.type:=array(num.val,T1.type);T.width:=num.valT1.width T.type:=pointer(T1.type);T.width:=4 22说明说明:(1)offset:全程变量全程变量,代表变量在过程数据区中的相对地址代表变量在过程数据区中的相对地址,用来跟踪下一个可用的相对地址的位置用来跟踪下一个可用的相对地址的位置.7.2 7.2 说明语句说明语句(2)enter(name,
15、type,offset):把名字把名字name符号表符号表,并给出此名字的类型并给出此名字的类型type及在及在过程数据区中的相对地址过程数据区中的相对地址offset.(3)综合属性综合属性:T.type名字的类型名字的类型;T.width名字的域宽名字的域宽(即该类型名字所占用即该类型名字所占用 的存储单元个数的存储单元个数)23二、保留作用域信息二、保留作用域信息1.1.嵌套过程中的说明语句嵌套过程中的说明语句7.2 7.2 说明语句说明语句(1)(1)相应的文法相应的文法:PD DD;D|id:T|proc id;D;S(2)(2)程序举例程序举例:247.2 说明语句说明语句2.含嵌
16、套说明的翻译模式:含嵌套说明的翻译模式:PM D addwidth(top(tblptr),top(offset);pop(tblptr);pop(offset)M t:=mktable(nil);push(t,tblptr);push(0,offset)D D1;D2D proc id;N D1;S t:=top(tblptr);addwidth(t,top(offset);pop(tblptr);pop(offset);enterproc(top(tblptr),id.name,t)N t:=mktable(top(tblptr);push(t,tblptr);push(0,offset)
17、D id:T enter(top(tblptr),id.name,T.type,top(offset);top(offset):=top(offset)+T.width 25(1)(1)语义规则中的操作语义规则中的操作:7.2 7.2 说明语句说明语句2.2.含嵌套说明的翻译模式:含嵌套说明的翻译模式:Mktable(previous):创建一张新符号表创建一张新符号表,并返回指向新表的一个指针并返回指向新表的一个指针;Enter(table,name,type,offset):在指针在指针tabletable指示的符号表中为名字指示的符号表中为名字namename建立一个新顶建立一个新顶,并
18、并把类型把类型typetype、相对地址、相对地址offsetoffset填入到该项中填入到该项中;267.2 7.2 说明语句说明语句(1)(1)语义规则中的操作语义规则中的操作:Enterproc(table,name,newtable):在指针在指针table指示的符号表中为名字指示的符号表中为名字name的过程建立一个的过程建立一个新顶。参数新顶。参数newtable指向过程指向过程name的符号表。的符号表。Addwidth(table,width):在指针在指针table指示的符号表表头中记录下该表中所有名字占指示的符号表表头中记录下该表中所有名字占用的总宽度用的总宽度;27(2)
19、(2)栈栈:tblptr:存放指向符号表的指针存放指向符号表的指针,栈顶为指向当前正在处理过栈顶为指向当前正在处理过 程的符号表指针程的符号表指针.offset:存放变量在数据区中的相对地址存放变量在数据区中的相对地址,栈顶为当前正在处栈顶为当前正在处 理过程的下一个变量的相对地址。理过程的下一个变量的相对地址。(3)top():取当前栈顶元素取当前栈顶元素 push(a,B):将将a a推进推进B B栈栈顶栈栈顶 pop(A):将将A A栈栈顶元素出栈栈栈顶元素出栈7.2 7.2 说明语句说明语句287.3 7.3 赋值语句的翻译赋值语句的翻译一、简单算术表达式及赋值语句一、简单算术表达式及
20、赋值语句1.1.产生产生“赋值语句赋值语句”三地址代码的翻译模式三地址代码的翻译模式:Sid:=E p:=lookup(id.name);if pnil then emit(p:=E.place)else error EE1+E2 E.place:=newtemp;emit(E.place:=E1.place+E2.place)EE1*E2 E.place:=newtemp;emit(E.place:=E1.place*E2.place)E-E1 E.place:=newtemp;emit(E.place:=uminusE1.place)E(E1)E.place:=E1.placeEid p:
21、=lookup(id.name);if pnil then E.place:=p else error292.说明说明:id.nameidid所代表的名字本身所代表的名字本身lookup(id.name)检查符号表中是否存在相应检查符号表中是否存在相应此名字的入口此名字的入口nil:返回一个该表项的指针返回一个该表项的指针 =nil:未找到未找到 emit()将生成的三地址语句发送到输出文件中将生成的三地址语句发送到输出文件中E.place存放存放E E值的名字值的名字newtemp产生产生“临时变量临时变量”7.3 7.3 赋值语句的翻译赋值语句的翻译303.例题:例题:写出下列代码段中表达
22、式的翻译制导过写出下列代码段中表达式的翻译制导过 程及其所产生的四元式程及其所产生的四元式beginInteger:B、C、D、X;X:=-B*(C+D);endOparg1arg2result(1)(2)(3)(4)+*:=T1 1T3 3T2 2T1 1T2 2T3 3符号表符号表四元式四元式7.3 7.3 赋值语句的翻译赋值语句的翻译31 已归约串已归约串PLACEPLACE输入串输入串语义动作语义动作#X:=-B X:=-B*(C+D)#(C+D)#X#X X X :=-B :=-B*(C+D)#(C+D)#X:=#X:=X_ X_-B-B*(C+D)#(C+D)#X:=-#X:=-X
23、_ X_ B B*(C+D)#(C+D)#X:=-B#X:=-B X_B X_B *(C+D)#(C+D)#X:=-E#X:=-E X_B X_B *(C+D)#E.place:=p=(C+D)#E.place:=p=#X:=E#X:=E1 1 X_T X_T1 1 *(C+D)#E(C+D)#E1 1.place:=newtemp=T.place:=newtemp=T1 1;生成四元式生成四元式(1)(1)#X:=E#X:=E*(C(C X_T X_T1 1_C_C +D)#+D)#X:=E#X:=E*(E1(E1X_TX_T1 1_C +D)#E_C +D)#E1 1.place:=p=.
24、place:=p=32 已归约串已归约串 PLACEPLACE 输入串输入串 语义动作语义动作#X:=E#X:=E*(E1+D X_T(E1+D X_T1 1_C_D_C_D)#)#X:=E#X:=E*(E1+E2 X_T(E1+E2 X_T1 1_C_D_C_D)#)#E E2 2.place:=p=.place:=p=#X:=E#X:=E*(E3(E3X_TX_T1 1_T_T2 2)#)#EE3 3.place:=newtemp=T.place:=newtemp=T2 2;生成四元式生成四元式(2)(2)#X:=E#X:=E*(E3)X_T(E3)X_T1 1_T_T2 2_ _#X:=
展开阅读全文