编译7语义分析和中间代码产生1(zss).ppt
《编译7语义分析和中间代码产生1(zss).ppt》由会员分享,可在线阅读,更多相关《编译7语义分析和中间代码产生1(zss).ppt(39页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、编译原理编译原理(第三版第三版)陈火旺等编著(2012201220122012年年年年9 9 9 9月月月月-12-12-12-12月)月)月)月)主讲:朱世松主讲:朱世松计算机学院计算机学院4/20/20231概述概述一、语义分析的任务一、语义分析的任务1.审查每一个语法结构的静态语义,即验证语法正确的结构是否有意义。如:赋值语句:x=x+y,左边变量类型与右边变量类型是否一致。2.在语义正确的基础上生成一种中间代码或目标代码。4/20/20232二、语义分析的范围二、语义分析的范围1.确定类型:确定标识符所关联的数据类型。2.类型检查:按语言的类型规则,检查运算的合法性与运算分量类型的一致
2、性,必要时作类型转换。3.识别含义:根据语言的语义定义(形式或非形式),识别程序中各构造成分组合到一起的含义,并作相应的语义处理(生成中间代码或目标代码)4.控制流检查:控制流语句必须转移到合法的地方。如:C中,break语句规定跳出最内层的循环或switch语句.4/20/202335.一致性检查:在很多场合要求对象只能被说明一次(避免重复定义)。6.相关名字检查:如:Ada,循环或块可以有一个名字,它出现在这些结构的开头或结尾。编译程序必须检查这两个地方用的名字是否相同。4/20/20234三、语义描述工具和语义分析方法三、语义描述工具和语义分析方法1.语义描述工具 目前流行:用属性文法属
3、性文法作为描述语义的工具。2.语义分析方法根据描述属性文法的语义规则的方式不同,语义分析方法分为:语法制导定义方法翻译方案4/20/202351 中间语言n中间语言:它介于源程序到目标语言程序中间程序的语言n中间语言程序:用中间语言表示的程序。n作用:用于编译程序,将源程序翻译成等价的中间语言程序,再将中间语言程序转化成目标程序(即将语义分析和目标代码生成分开处理)n源程序 中间语言程序目标程序n中间语言是表示语法制导翻译的结果。等价变换转化7.1 7.1 中中 间间 语语 言言4/20/20236好处:n中间语言与机器无关,使采用中间语言进行翻译的编译程序系统易于移植。n易于优化翻译后的代码
4、。n使编译程序的结构在逻辑上更简单明确。2 中间语言的表示常见:逆波兰表示 四元式表示和三地址代码、三元式 图表示:DAG和树形表示4/20/202377.1.1 逆波兰表示逆波兰表示 由波兰逻辑学家J.Lukasiewicz(卢卡西维兹)首先提出用来表示表达式的方法,后来推广到表示程序设计语言中的其它语法成分。1.表达式的逆波兰表示表达式的逆波兰表示2.表达式的表示:n中缀表示:运算符居中,运算对象在左右两边:a+bn波兰表示:前缀表示:运算符在前,运算对象在后:+ab后缀表示:运算对象在前,运算符在后:ab+(逆波兰表示)4/20/20238n例:逆波兰表示的例子中缀表示(一般表示)逆波兰
5、表示a+b*cabc*+a*(b+c/d)abcd/+*a*b+cab*c+a*b+(c-d)/eab*cd-e/+4/20/20239(1)表达式逆波兰表示的定义:设E是一般表达式,则:一般表达式一般表达式逆波兰表达式逆波兰表达式n若E为变量或常量En(E)E的逆波兰式nE(1)opE(2)(二目运算)E(1)的逆波兰式 E(2)的逆波兰式 opnopE(单目运算)E的逆波兰式 op4/20/202310把表达式翻译成后缀式的语义规则描述把表达式翻译成后缀式的语义规则描述 产生式产生式EE(1)op E(2)E(E(1)Eid语义动作语义动作E.code:=E(1).code|E(2).co
6、de|opE.code:=E(1).codeE.code:=idE.code表示表示E后缀形式后缀形式op表示任意二元操作符表示任意二元操作符“|”表示后缀形式的连接表示后缀形式的连接。4/20/202311 (2)逆波兰表示的特点a.标识符(运算对象)出现的顺序(从左到右)和原有顺序相同。b.运算符是按实际计算顺序(从左到右)出现的。c.运算符紧跟在运算对象的后面出现,并且没有括号。4/20/202312(3)好处:易于对表达式的计算处理n对于一般表达式的计算,系统需要用两个工作栈分别处理运算对象和运算符。n对于逆波兰表示的表达式计算处理只用一个工作栈。一一般般的的计计算算过过程程是是:自自
7、左左至至右右扫扫描描后后缀缀式式,每每碰碰到到运运算算量量就就把把它它推推进进栈栈。每每碰碰到到k目目运运算算符符就就把把它它作作用用于于栈栈顶顶的的k个个项项,并并用用运运算算结结果果代代替替这这k个项个项。4/20/202313例:逆波兰式ab+c*的计算处理过程遇运算对象a,b入栈扫描ab+c*ba栈遇二目运算符+c*取出a,b,运算结果T入栈TcT取出c,T作运算,设结果T1T1遇运算符*c*遇运算对象c入栈4/20/2023142.形成逆波兰表示怎样将一般表达式转换成逆波兰表示?基本思想基本思想:从左到右扫描表达式,每遇到:1o 表达式中的运算对象则往左去。2o 表达式中的运算符,则
8、与运算符栈顶元素比较优先数:4/20/202315逆波兰表示表达式运算对象运算符进栈出栈运算符栈 如果运算符栈顶元素的优先数大于或等于表达式中当前的运算符优先数,则栈顶元素退栈向左去。然后当前运算符继续与栈顶的新元素比较优先数。直到栈顶元素的优先数小于表达式中当前运算符为止。此时,才将表达式中当前运算符进栈。4/20/202316例:画出形成表达式a*(b+c/d)的逆波兰表示过程a*(b+c/d)#步骤a(b+c/d)#*#步骤ab+c/d)#(*#步骤ab+c/d)#(*#步骤abc/d)#+(*#步骤abc/d)#+(*#步骤4/20/202317abcd)#/+(*#步骤abcd)#/
9、+(*#步骤/+(*#abcd/)#步骤+(*#abcd/+)#步骤*#abcd/+*#步骤4/20/202318形成逆波兰表示的过程,实质上是表达式的翻译过程。(算法不难写出)例:a/b/c+d=ab/c/d+(a+b)*(c-d/e)=ab+cde/-*4/20/202319n数组数组POST存放后缀式:存放后缀式:k为下标,初值为为下标,初值为1n上述语义动作可实现为:上述语义动作可实现为:产生式产生式程序段程序段EE(1)op E(2)POSTk:=op;k:=k+1E(E(1)EiPOSTk:=i;k:=k+1n例:输入串例:输入串a+b+c的分析和翻译的分析和翻译POST:1 2
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 语义 分析 中间 代码 产生 zss
限制150内