程序设计语言编译原理(第三版)第7章.ppt
《程序设计语言编译原理(第三版)第7章.ppt》由会员分享,可在线阅读,更多相关《程序设计语言编译原理(第三版)第7章.ppt(67页珍藏版)》请在三一办公上搜索。
1、1,第七章语义分析和中间代码产生,一般情况下,在词法分析程序和语法分析程序对源程序的语法结构进行分析之后,要么,由语法分析程序直接调用相应的语义子程序进行语义处理;要么,首先生成语法树或该结构的某种表示,再进行语义处理。,2,语义处理分两步:1.静态语义分析,即验证语法结构合法的程序是否真正有意义。2.若静态语义正确,语义处理则要执行真正的翻译。即要么生成程序的一种中间表示形式(中间代码),要么生成实际的目标代码。,静态语义检查包括:(1)类型检查;(2)控制流检查;(3)一致性检查;(4)相关名字检查。,第七章语义分析和中间代码产生,3,中间代码:即中间语言,独立于机器的,复杂性介于源语言和
2、机器语言之间的一种表示形式。,采用中间语言的好处:,第七章语义分析和中间代码产生,(1)便于进行与机器无关的代码优化工作;,(2)使编译程序改变目标机更容易;,(3)使编译程序的结构在逻辑上更为简单明确。,4,7.1 中间语言 7.2 说明语句 7.3 赋值语句的翻译 7.4 布尔表达式的翻译 7.5 控制语句的翻译 7.6 过程调用的处理(略)7.7 类型检查(略),第七章语义分析和中间代码产生,5,7.中间语言,中间语言形式:后缀式三地址代码 图表示法,6,一、后缀式逆波兰式:,规则:,7.中间语言,(1)E常量变量:后缀式为E本身,(2)EE1 op E2:E1 E2 op,(3)E(E
3、1):(E1),(4)Eop E1:E1 op,7,7.中间语言,例子:,a*(b+c),(a+b)*(c+d),abc+*,x+yza0(8+z)3,ab+cd+*,xy+za08z+3,8,二、图表示法,1.DAG(无循环有向图)与抽象语法树对比 相同点:对表达式中的每个子表达式,它们都有一个结 点,一个内部结点代表一个操作符,它的孩子 代表操作数;不同点:在一个DAG中代表公共子表达式的结点具有多个 父结点,而在一棵抽象语法树中公共子表达式 被表示为重复的子树。,7.中间语言,9,例子:如图所示,为a+a*(b-c)+(b-c)*d的DAG,7.中间语言,10,2.抽象语法树,例子:(1
4、)a:=b*-c+b*-c的图表示法,7.中间语言,11,(2)a:=b*-c+b*-c 的抽象语法树的两种表示法,012345678910,7.中间语言,12,三、三地址代码,1.三地址代码:下面一般形式的语句构成的序列:x:=y op zT1:=y*z,T2:=x+T1,称为三地址代码的原因:每条语句通常包含三个地址,两个用来表示操作数,一个用来存放结果。,7.中间语言,具体实现:用记录表示,其中包含运算符和操作数的域。,x,y,z:名字,常数,编译时产生的临时变量 op:运算符号(如定点运算符,浮点运算符,逻辑运算符等),13,2.四元式:带有四个域的记录结构,7.中间语言,(op,ar
5、g1,arg2,result),14,7.中间语言,例子:三地址语句a:=b*-c+b*-c的四元式表示,四元式表示,15,3.三元式:为了避免把临时变量填入符号表,可通过计算该临时变量值的语句的位置来引用该临时变量。,7.中间语言,(op,arg1,arg2),16,7.中间语言,例子:三地址语句a:=b*-c+b*-c的三元式表示,17,4.间接三元式:便于代码优化处理方法:间接码表+三元式表,例:语句X:=(A+B)*C;Y:=D(A+B)的间接三元式表示如下所示:,三元式表,7.中间语言,18,7.2 说明语句,编译过程中,对“说明语句”要做的工作:,对一个过程或分程序的一系列说明语句
6、,考察时:,(1)需要为局部于该过程的名字分配存储空间;,(2)对每个局部名字,都需在符号表中建立相应的表项,并填入有关的信息如类型、在存储器中的相对地址 等。,19,一、过程中的说明语句,1.产生“说明语句”的文法:,PDDD;DDid:T TintegerTrealTarraynum of T1TT1,7.2 说明语句,20,2.处理方式:处理第一条说明语句之前,先置offset为0,以后每次遇到一个新的名字,则:(1)将该名字填入符号表中,(2)置相对地址为当前offset之值,(3)使offset加上该名字所表示的数据对象的域宽。,7.2 说明语句,21,3.相应的翻译模式:,7.2
7、说明语句,PDDD;DDid:T TintegerTrealTarraynum of T1TT1,offset:=0,enter(id.name,T.type,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:全程变量,代表变量在过程数据区中的相对地址,用来跟踪下一个可
8、用的相对地址的位置.,7.2 说明语句,(2)enter(name,type,offset):把名字name符号表,并给出此名字的类型type及在过程数据区中的相对地址offset.,(3)综合属性:T.type名字的类型;T.width名字的域宽(即该类型名字所占用 的存储单元个数),23,二、保留作用域信息,1.嵌套过程中的说明语句,7.2 说明语句,(1)相应的文法:PD DD;D|id:T|proc id;D;S,(2)程序举例:,24,7.2 说明语句,2.含嵌套说明的翻译模式:,PM D addwidth(top(tblptr),top(offset);pop(tblptr);po
9、p(offset),M t:=mktable(nil);push(t,tblptr);push(0,offset),D D1;D2,D 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),D id:T enter(top(tblptr),id.name,T.type,top(offset);top(offset):=to
10、p(offset)+T.width,25,(1)语义规则中的操作:,7.2 说明语句,2.含嵌套说明的翻译模式:,Mktable(previous):创建一张新符号表,并返回指向新表的一个指针;,Enter(table,name,type,offset):在指针table指示的符号表中为名字name建立一个新顶,并把类型type、相对地址offset填入到该项中;,26,7.2 说明语句,(1)语义规则中的操作:,Enterproc(table,name,newtable):在指针table指示的符号表中为名字name的过程建立一个新顶。参数newtable指向过程name的符号表。,Addw
11、idth(table,width):在指针table指示的符号表表头中记录下该表中所有名字占用的总宽度;,27,(2)栈:tblptr:存放指向符号表的指针,栈顶为指向当前正在处理过 程的符号表指针.offset:存放变量在数据区中的相对地址,栈顶为当前正在处 理过程的下一个变量的相对地址。,(3)top():取当前栈顶元素 push(a,B):将a推进B栈栈顶 pop(A):将A栈栈顶元素出栈,7.2 说明语句,28,7.3 赋值语句的翻译,一、简单算术表达式及赋值语句,1.产生“赋值语句”三地址代码的翻译模式:,Sid:=E p:=lookup(id.name);if pnil then
12、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.place,Eid p:=lookup(id.name);if pnil then E.place:=p else error,29,2.说明:id.nameid所代表的名字本身l
13、ookup(id.name)检查符号表中是否存在相应此名字的入口nil:返回一个该表项的指针=nil:未找到 emit()将生成的三地址语句发送到输出文件中E.place存放E值的名字newtemp产生“临时变量”,7.3 赋值语句的翻译,30,3.例题:写出下列代码段中表达式的翻译制导过 程及其所产生的四元式beginInteger:B、C、D、X;X:=-B*(C+D);end,符号表,四元式,7.3 赋值语句的翻译,31,已归约串PLACE输入串语义动作#X:=-B*(C+D)#X X:=-B*(C+D)#X:=X_-B*(C+D)#X:=-X_ B*(C+D)#X:=-B X_B*(C
14、+D)#X:=-E X_B*(C+D)#E.place:=p=#X:=E1 X_T1*(C+D)#E1.place:=newtemp=T1;生成四元式(1)#X:=E*(C X_T1_C+D)#X:=E*(E1X_T1_C+D)#E1.place:=p=,32,已归约串 PLACE 输入串 语义动作#X:=E*(E1+D X_T1_C_D)#X:=E*(E1+E2 X_T1_C_D)#E2.place:=p=#X:=E*(E3X_T1_T2)#E3.place:=newtemp=T2;生成四元式(2)#X:=E*(E3)X_T1_T2_#X:=E*E4 X_T1_T2#E4.place=E3.
15、place=T2#X:=E5X_T3#E5.place=T3;生成四元式(3)#S#p:=lookup(X.name);生成四元式(4),33,二、数组元素的引用,1.数组元素在存储器中的存放:,7.3 赋值语句的翻译,一维数组地址:,二维数组地址:,Ai 的地址=base+(i-low)*w=i*w+(base-low*w),Ai1,i2 的地址=base+(i1 low1)*n2+i1-low2)*w=(i1*n2)+i2)*w+(base(low1*n2)+low2)*w),34,7.3 赋值语句的翻译,1.数组元素在存储器中的存放:,二、数组元素的引用,k维数组地址:,C=(low1
16、n2+low2)n3+low3)nk+lowk)*w,变量部分:((i1 n2+i2)n3+i3))nm+i m e1=i1,em=em-1*n m+im,A i1,i2,ik 的地址=(i1 n2+i2)n3+i3))nk+ik)*w+base(low1 n2+low2)n3+low3)nk+lowk)*w,35,改写产生式的原因:使我们在整个下标表达式串Elist的翻译过程中随时都能知道符号表中相应于数组名字id的符号表入口,从而随时能了解登记在符号表中的有关数组id的全部信息。,7.3 赋值语句的翻译,36,3.数组元素的翻译模式:A.文法:(1)SL:=E(2)EE+E(3)E(E)(
17、4)EL(5)LElist(6)Lid(7)ElistElist,E(8)Elistid E,7.3 赋值语句的翻译,37,B.说明:id.placeid的符号表入口.E.place存放E的名字/值.L.offset=null,L为简单名字;null,L为数组元素引用,存放临时变量的值.(变量部分的值)L.place L简单名字,则指向符号表中相应此名字表项的 指针,即此名字的符号表入口.L数组引用,则L.place存放临时变量的值.(常量部分的值),7.3 赋值语句的翻译,38,7.3 赋值语句的翻译,B.说明:Elist.array用来记录指向符号表中相应数组名字 表项的指针数组变量的符号
18、表入口 Elist.place表示临时变量,用来临时存放由Elist中的 下标表达式计算出的值。Elist.ndim记录Elist中的下标表达式的个数,即 维数。Limit(array,j)返回nj,即由array所指示的数组的 第j维长度。,39,7.3 赋值语句的翻译,C.翻译模式,S L:=E if L.offset=null then emit(L.place:=E.place)else emit(L.place L.offset:=E.place),(2)E E1+E2 E.place:=newtemp;Emit(E.place:=E1.place+E2.place),(3)E(E1
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计语言 编译 原理 第三
链接地址:https://www.31ppt.com/p-6011266.html