语义分析和中间代码生成精品文稿.ppt
《语义分析和中间代码生成精品文稿.ppt》由会员分享,可在线阅读,更多相关《语义分析和中间代码生成精品文稿.ppt(118页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、语义分析和中间代语义分析和中间代码生成码生成第1页,本讲稿共118页本章在编译程序中的地位本章在编译程序中的地位表格管理词法分析器语法分析器语义分析与中间代码产生优化器目标代码生成器源程序单词符号语法单位中间代码中间代码目标代码出错处理第2页,本讲稿共118页6.1概述6.2属性文法6.3几种常见的中间语言(*四元式)6.4表达式及赋值语句的翻译6.5控制语句的翻译6.6数组元素的翻译6.7过程或函数调用语句的翻译*6.8说明语句的翻译内容安排内容安排第3页,本讲稿共118页6.1概概述述6.1.1语义分析的概念一个源程序经过词法分析、语法分析之后,表明该源程序在书写上是正确的,并且符合程序语
2、言所规定的语法。但是语法分析并未对程序内部的逻辑含义加以分析,因此编译程序接下来的工作是语义分析,即审查每个语法成分的静态语义。如果静态语义正确,则生成与该语言成分等效的中间代码,或者直接生成目标代码。第4页,本讲稿共118页l直接生成目标代码直接生成机器语言或汇编语言形式的目标代码的优点是编译时间短且无需中间代码到目标代码的翻译。l生成中间代码生成中间代码的优点是使编译结构在逻辑上更为简单明确,特别是使目标代码的优化比较容易实现。第5页,本讲稿共118页 语义分析时语义检查的分类:u动态语义检查 需要生成相应的目标代码,它是在运行时进行的;例如:除零溢出错误。u静态语义检查 在编译时完成的,
3、它涉及以下几个方面:(1)类型检查 (2)控制流检查 (3)一致性检查第6页,本讲稿共118页各种条件表达式的类型不是布尔类型;运算符的分量类型不相容;赋值语句左右类型不相容;形、实参类型不相容;函数说明和函数返回类型不相容;int x;float f();x=f();符合变量声明的语法、语义符合函数声明的语法、语义符合赋值语句的语法、不符合语义(1)类型检查第7页,本讲稿共118页 (2)控制流检查 用以保证控制语句有合法的转向点。如C语言中不允许goto语句转入case语句流;break语句需寻找包含它的最小switch、while或for语句方可找到转向点,否则出错。(3)一致性检查 如
4、在相同作用域中标识符只能说明一次、case语句的标号不能相同、函数调用参数个数要相同等。第8页,本讲稿共118页常见的语义错误声明和使用相关的语义错误标识符没有声明;重复声明;如何检查?每当遇到新声明的标识符,查符号表如果当前有效的所有标识符中有相同名字的,则是重复声明错误;否则生成它的属性信息,保存到符号表中;每当遇到标识符的使用,查符号表如果没有找到,说明该标识符没有声明;否则,得到该标识符的属性,进行进一步分析;第9页,本讲稿共118页语义分析阶段只产生中间代码而不生成目标代码的方法使编译程序的开发变得较为容易,但语义分析不像词法分析和语法分析那样可以分别用正规文法和上下文无关文法描述。
5、由于语义是上下文有关的,因此语义的形式化描述是非常困难的,目前较为常见的是用属性文法作为描述程序语言语义的工具,并采用语法制导翻译的方法完成对语法成分的翻译工作。第10页,本讲稿共118页语法制导翻译的方法就是为每个规则配上一个翻译子程序(称语义动作或语义子程序),并在语法分析的同时执行这些子程序。语义动作是为规则赋予具体意义的手段,它一方面指出了一个规则所产生的符号串的意义,另一方面又按照这种意义规定了生成某种中间代码应做哪些基本动作。在语法分析过程中,当一个规则获得匹配(对于自上而下分析)或用于归约(对于自下而上分析)时,此规则相应的语义子程序就进入工作,完成既定的翻译任务。6.1.2语法
6、制导翻译方法第11页,本讲稿共118页语法制导翻译分为自下而上语法制导翻译和自上而下语法制导翻译,我们重点介绍自下而上语法制导翻译。假定有一个自下而上的LR分析器,我们可以把这个LR分析器的能力加以扩大,使它能在用某个规则进行归约的同时调用相应的语义子程序进行有关的翻译工作;每个规则的语义子程序执行之后,某些结果(语义信息)必须作为此规则的左部符号的语义值暂时保存下来,以便以后语义子程序引用这些信息。第12页,本讲稿共118页此外,原LR分析器的分析栈也加以扩充,以便能够存放与文法符号相对应的语义值。这样,分析栈可以存放三类信息:分析状态、文法符号及文法符号对应的语义值。扩充后的分析栈如图61
7、所示。第13页,本讲稿共118页图图61扩充后的扩充后的LR分析栈分析栈第14页,本讲稿共118页作为一个例子,我们考虑下面的文法及语义动作所执行的程序:规则语义动作(0)SE printvalTOP(1)EE(1)+E(2)valTOP=valTOP+valTOP+2(2)EE(1)*E(2)valTOP=valTOP*valTOP+2(3)E(E(1)valTOP=valTOP+1(4)EivalTOP=lexval(注:lexval为i的整型内部值)第15页,本讲稿共118页我们扩充分析栈工作的总控程序功能,使其在完成语法分析的同时也能完成语义分析工作(这时的语法分析栈已成为语义分析栈)
8、;即在用某一个规则进行归约之后,调用相应的语义子程序完成与所用规则相应的语义动作,并将每次工作后的语义值保存在扩充后的“语义值”栈中。图62表示算术表达式79*5#的语法树及各结点值,而表6.1则给出了根据分析表用LR语法制导翻译方法得到的该表达式的语义分析和计值过程。第16页,本讲稿共118页图图62语法制导翻译计算表达式语法制导翻译计算表达式79*5#的语法树的语法树第17页,本讲稿共118页表表6.1表达式表达式79*5#的语义分析和计值过程的语义分析和计值过程步骤状态栈符号栈语义栈输入串动作10#_79*5#s3203#7_9*5#r4301#E_79*5#s44014#E+_7_9*
9、5#s350143#E+9_7_*5#r460147#E+E_7_9*5#s5701475#E+E*_7_9_5#s38014753#E+E*5_7_9_#r49014758#E+E*E_7_9_5#r2100147#E+E_7_45#r11101#E_52#acc第18页,本讲稿共118页6.2属属性性文文法法6.2.1文法的属性属性是指与文法符号的类型和值等有关的一些信息,在编译中用属性描述处理对象的特征。随着编译的进展,对语法分析产生的语法树进行语义分析,且分析的结果用中间代码描述出来。对于一棵等待翻译的语法树,它的各个结点都是文法中的一个符号X,该X可以是终结符或非终结符。根据语义处理
10、的需要,在用规则AX进行归约或推导时,应能准确而恰当地表达文法符号X在归约或推导时的不同特征。第19页,本讲稿共118页 例如:判断变量X的类型是否匹配,要用X的数据类型来描述;判断变量X是否存在,要用X的存储位置来描述;而对X的运算,则要用X的值来描述;因此,语义分析阶段引入X的属性,如X.type、X.place、X.val等来分别描述变量X的类型、存储位置以及值等不同的特征。文法符号属性分:n 继承属性n 综合属性第20页,本讲稿共118页继承属性用于“自上而下”传递信息。继承属性由相应语法树中结点的父结点属性计算得到,即沿语法树向下传递,由根结点到分枝(子)结点,它反映了对上下文依赖的
11、特性。继承属性可以很方便地用来表示程序语言上下文的结构关系。综合属性用于“自下而上”传递信息。综合属性由相应语法分析树中结点的分枝结点(即子结点)属性计算得到,其传递方向与继承属性相反,即沿语法分析树向上传递,从分枝结点到根结点。第21页,本讲稿共118页 属性文法 是一种适用于定义语义的特殊文法,即在语言的文法中增加了属性的文法,它将文法符号的语义以“属性”的形式附加到各个文法的符号上(如 上 述 与 变 量 X相 关 联 的 属 性 X.type、X.place和X.val等),再根据规则所包含的含义,给出每个文法符号属性的求值规则,从而形成一种带有语义属性的上下文无关文法,即属性文法。属
12、性文法也是一种翻译文法,属性有助于更详细地指定文法中的代码生成动作。6.2.2 属性文法第22页,本讲稿共118页例如,简单算术表达式求值的属性文法如下:规则语义规则(1)SEprint(E.val)(2)EE(1)+TE.val=E(1).val+T.val(3)ETE.val=T.val(4)TT(1)*FT.val=T(1).val*F.val(5)TT(1)T.val=T(1).val(6)F(E)F.val=E.val(7)FiF.val=i.lexval第23页,本讲稿共118页上面的一组规则中,每一个非终结符都有一个属性val来表示整型值,如E.val表示E的整型值,而i.lex
13、val则表示i的整型内部值。与规则关联的每一个语义规则的左部符号E、T、F等的属性值的计算由其各自相应的右部符号决定,这种属性也称为综合属性。与规则SE关联的语义规则是一个函数print(E.val),其功能是打印E规则的值。S在语义规则中没有出现,可以理解为其属性是一个虚属性。第24页,本讲稿共118页简单变量类型说明的文法GD如下:GD:DintLfloatLLL,idid其对应的属性文法为:规则语义规则(1)DTLL.in=T.type(2)TintT.type=int(3)TfloatT.type=float(4)LL(1),idL(1).in=L.in;addtype(id.entr
14、y,L.in)(5)Lidaddtype(id.entry,L.in)注意到与文法GD相应的说明语句形式可为intid1,id2,,idn或者floatid1,id2,,idn第25页,本讲稿共118页非终结符T有一个综合属性type,其值为int或float。语义规则L.in=T.type表示L.in的属性值由相应说明语句指定的类型T.type决定;属性L.in被确定后将随语法树的逐步生成而传递到下边的有关结点使用,这种结点属性称为继承属性。由此可见,标识符的类型可以通过继承属性的复写规则来传递。例如,对输入串inta,b,根据上述的语义规则,可在其生成的语法树中看到用“”表示的属性传递情况
15、,如图63所示。第26页,本讲稿共118页图图63属性信息传递情况示意属性信息传递情况示意第27页,本讲稿共118页属性翻译文法(属性文法)属性翻译文法(属性文法)第28页,本讲稿共118页6.3几种常见的中间语言几种常见的中间语言6.3.1 抽象语法树6.3.2逆波兰表示法6.3.3三地址代码第29页,本讲稿共118页6.3.1 6.3.1 抽象语法树抽象语法树语法制导翻译既可以基于语法分析树也可以基于抽象语法语法制导翻译既可以基于语法分析树也可以基于抽象语法树进行,采用的基本方法是一样的。树进行,采用的基本方法是一样的。现在对语法树进行改造,去掉那些对翻译不必要的信息,现在对语法树进行改造
16、,去掉那些对翻译不必要的信息,将语法树进行抽象将语法树进行抽象 -抽象语法树。抽象语法树。在表达式的抽象语法树中,运算符、关键字不作叶子结点在表达式的抽象语法树中,运算符、关键字不作叶子结点而作为内部结点,叶子结点只是运算量。而作为内部结点,叶子结点只是运算量。语法制导翻译以语法树作基础语法制导翻译以语法树作基础,实际上实际上,语法树可以作为一语法树可以作为一种合适的中间语言形式。种合适的中间语言形式。抽象语法树也可以属性化,给结点加上属性变成带属性的抽象语法树也可以属性化,给结点加上属性变成带属性的抽象语法树。抽象语法树。第30页,本讲稿共118页当把语法规则中本质部分抽象出来而将非本质部分
17、去掉后,便得到抽象语法规则。这种去掉不必要信息的做法可以获得高效的源程序中间表示。如赋值语句x=ab*c的抽象语法树如图64(a)所示,而图64(b)则是该赋值语句的普通语法树。图图64x=ab*c的语法树的语法树第31页,本讲稿共118页抽象语法树的一个显著特点是结构紧凑,容易构造且结点数较少。图64(b)所示的普通语法树的结点为14个;而图64(a)所示的抽象语法树的结点仅有7个,且每个内部结点最多只有两个分支,因此可以将每个赋值语句或表达式表示为一棵二叉树。对于含有多元运算的更为复杂的语法成分,相应的抽象语法树则为一棵多叉树,但我们总可以将其转变为一棵二叉树。第32页,本讲稿共118页为
18、下面文法的句子为下面文法的句子 a-4+ca-4+c 建立抽象语法树。建立抽象语法树。EE+T|ET|TT(E)Tid|num为每个运算量或运算符号都建立一个结点。为每个运算量或运算符号都建立一个结点。可以可以根据表达式的运算顺序自下而上的构造根据表达式的运算顺序自下而上的构造-手工构造。手工构造。a+c4抽象语法树抽象语法树运算符作内运算符作内部结点部结点id(a)EETE+TTnum(4)id(c)语法树语法树第33页,本讲稿共118页抽象语法树的实现抽象语法树的实现抽象语法树中的每一个抽象语法树中的每一个结点可以由包含几个域的记录来实现;结点可以由包含几个域的记录来实现;有向边用指针实现
19、有向边用指针实现。在一个在一个运算量运算量对应的结点对应的结点(叶结叶结)中中,一个域标识运算量,另一个一个域标识运算量,另一个域是该运算量的属性值域是该运算量的属性值(或指针或指针)。在一个在一个运算符运算符对应的结点中对应的结点中,一个域标识运算符,其它域包含指一个域标识运算符,其它域包含指向运算分量的结点的指针。运算符通常叫做这个结点的向运算分量的结点的指针。运算符通常叫做这个结点的标号标号。进行翻译时,抽象语法树中的结点可能会进行翻译时,抽象语法树中的结点可能会用附加域来存放结点用附加域来存放结点的属性值的属性值(或指向属性的指针)。或指向属性的指针)。numvalid.op.Toen
20、tryofid右子树根结右子树根结左子树根结左子树根结第34页,本讲稿共118页建建立立表表达达式式的的抽抽象象语语法法树树使使用用的的函函数数,这这些些函函数数返返回回新新建建立立结结点点的的指指针。针。1.mknode(op,left,right)建建立立一一个个运运算算符符结结点点,标标号号是是op,两个域两个域left和和right指向左右运算分量结点的指针。指向左右运算分量结点的指针。2.mkleaf(id,entry)建建立立一一个个“标标识识符符”叶叶子子结结点点,由由标标号号id标识,一个域标识,一个域entry指向标识符在符号表中相应的项。指向标识符在符号表中相应的项。3.m
21、kleaf(num,val)建建立立一一个个“数数”叶叶子子结结点点,标标号号为为num,域,域val用于存放数的值。用于存放数的值。抽象语法树的构造函数抽象语法树的构造函数 第35页,本讲稿共118页 调调用用上上述述函函数数建建立立表表达达式式 a-4+ca-4+c 的的抽抽象象语语法法树树。建立顺序自下而上是建立顺序自下而上是:p1,p2,p3,p4,p5p1,p2,p3,p4,p5抽象语法树构造抽象语法树构造idtoentryap1num4p2p3idtoentrycp4+p5第36页,本讲稿共118页规则语义规则EE1+TE.nptr:=mknode(+,E1.nptr,T.nptr
22、)EE1-TE.nptr:=mknode(-,E1.nptr,T.nptr)ETE.nptr:=T.nptrT(E)T.nptr:=E.nptrTidT.nptr:=mkleaf(id,id.entry)TnumT.nptr:=mkleaf(num,num.val)建立抽象语法树的语义规则建立抽象语法树的语义规则属性文法属性文法,nptr,nptr是综合属性是综合属性第37页,本讲稿共118页n手手工工构构造造表表达达式式ab*(c-d)-e/f的的抽抽象象语语法法树树,根根据表达式的运算顺序自下而上的构造。据表达式的运算顺序自下而上的构造。练习练习 +adc*b/fe第38页,本讲稿共118
23、页逆波兰表示法是波兰逻辑学家卢卡西维奇(Lukasiewicz)发明的一种表示表达式的方法,这种表示法把运算量(操作数)写在前面,把运算符写在后面,因而又称后缀表示法。例如,把a+b写成ab+,把a*(b+c)写成abc+*。6.3.2逆波兰表示法第39页,本讲稿共118页1表达式的逆波兰表示表达式E的后缀表示的递归定义如下:(1)如果E是变量或常数,则E的后缀表示即E自身。(2)如果E为E1 op E2形式,则它的后缀表示为 E1E2op;其中op是二元运算符,而E1、E2分别又是E1和E2的后缀表示。若op为一元运算符,则视E1和E1为空。(3)如果E为(E1)形式,则E1的后缀表示即为E
24、的后缀表示。第40页,本讲稿共118页上述递归定义的实质是:后缀表示中,操作数出现的顺序与原来一致,而运算符则按运算先后的顺序放入相应的操作数之后(即运算符先后的顺序发生了变化)。这种表示已不再需要用括号来规定运算的顺序了。第41页,本讲稿共118页写表达式的后缀式写表达式的后缀式要点要点:1.后缀式中运算量的顺序与中缀式的相同;后缀式中运算量的顺序与中缀式的相同;2.算符出现的次序即表达式的运算次序;算符出现的次序即表达式的运算次序;3.不使用括号。不使用括号。例:例:a+bab+a*(b+c)abc+*(a+b)*(c+d)ab+cd+*-a+b*ca bc*+a/b*c-d*eabc*/
25、de*-(A0B0)A0=B0 用用 表示取负表示取负算符算符(uminus)第42页,本讲稿共118页练习练习写出下列各式的逆波兰表示写出下列各式的逆波兰表示:(1)-a-(b*c/(c-d)+(-b)*a)(2)-A+B*C(D/E)/F(3)x:=a-b/(c+d)n解:解:(1)a bc*cd-/b a*+-(2)A BCDE/*F/+(3)xabcd+/-:=用用 表示取负算符表示取负算符(uminus):=表示赋值算符表示赋值算符(assign)第43页,本讲稿共118页后缀表示法表示表达式,其最大优点是后缀表示法表示表达式,其最大优点是易于计易于计算机处理算机处理表达式。常用的算
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语义 分析 中间 代码 生成 精品 文稿
限制150内