补充:PL0编译程序的实现.ppt_第1页
补充:PL0编译程序的实现.ppt_第2页
补充:PL0编译程序的实现.ppt_第3页
补充:PL0编译程序的实现.ppt_第4页
补充:PL0编译程序的实现.ppt_第5页
已阅读5页,还剩51页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1,第二章 PL/0编译程序的实现,本章目的:以PL/0为例学习编译程序实现的基本步骤和相关技术,熟悉并理解编译程序的基本原理和概念。,PL/0编译程序,pcode解释程序,PL/0源程序,3,第二章 PL/0编译程序的实现,步骤1、 认识源语言PL/0与目标代码pcode及它们之间的映射 步骤2、 PL/0编译程序的总体设计 步骤3、 PL/0编译程序词法分析的设计与实现 步骤4、 PL/0编译程序语法语义分析的设计与实现,4,第二章 PL/0编译程序的实现,步骤5、 PL/0编译程序代码生成的实现 步骤6、 PL/0编译程序语法错误处理的实现 步骤7、 pcode代码解释器的设计与实现,5,步骤1、认识源语言PL/0与目标代码pcode及它们之间的映射,何为PL/0语言? 认识目标代码pcode PL/0程序到pcode代码的映射,6,何为PL/0语言?,PL/0语言:PASCAL语言的子集,功能简单,结构清晰,可读性强,具备了一般高级语言的必备部分 PL/0程序示例 PL/0的非形式描述 PL/0的语法描述图 PL/0语言文法的EBNF表示,7,PL/0程序示例,CONST A=10; VAR B,C; PROCEDURE P; VAR D; PROCEDURE Q; VAR X; BEGIN READ(X); D:=X; WHILE X#0 DO CALL P; END;,BEGIN WRITE(D); CALL Q; END; BEGIN CALL P; END.,8,PL/0非形式描述,数据类型只有整型 标识符的有效长度是10,以字母开始的字母数字串 数最多为14位 过程无参,可嵌套(最多三层),可递归调用 变量的作用域同PASCAL,常量为全局的,无标号,9,PL/0非形式描述,语句类型:赋值语句,if.then., while.do., read, write, call, 复合语句begin. end, 说明语句: const., var., procedure 13个保留字:if, then, while, do, read, write, call, begin, end, const, var, procedure, odd,10,PL/0的语法描述图,11,PL/0语言文法的EBNF表示,BNF与EBNF的介绍 BNF(BACKUS-NAUR FORM)是根据美国的John W.Backus与丹麦的Peter Naur来命名的,它从语法上描述程序设计语言的元语言。采用BNF就可说明哪些符号序列是对于某给定语言在语法上有效的程序。,12,PL/0语言文法的EBNF表示,BNF与EBNF的介绍 BNF引入的符号: 用左右尖括号括起来的语法成分为非终结符 = 定义为 | 或 EBNF引入的符号: 表示花括号内的语法成分可重复 表示方括号内的语法成分为任选项 ( ) 表示圆括号内的成分优先,13,PL/0语言文法的EBNF表示,BNF与EBNF的介绍 一个用EBNF描述的例子: =+|- =0|1|2|3|4|5|6|7|8|9,14,PL/0语言文法的EBNF表示,BNF与EBNF的介绍 =+|-|0 =1|2|3|4|5|6|7|8|9 =0|1|2|3|4|5|6|7|8|9,15,PL/0语言文法的EBNF表示,PL/0语言文法的EBNF表示 程序=分程序. 分程序=常量说明部分变量说明部分过程说明部分语句 常量说明部分=CONST常量定义部分,常量定义; 无符号整数=数字数字 变量说明部分=VAR标识符,标识符; 标识符=字母字母|数字 ,16,认识目标代码pcode,目标代码pcode是一种假想栈式计算机的汇编语言。 指令格式,f l a,f 功能码 l 层次差 a 根据不同的指令有所区别,0 jmp 0 8 1 jmp 0 2 2 int 0 3 3 lod 1 3 4 lit 0 10 5 opr 0 2 次栈顶与栈顶相加 6 sto 1 4 7 opr 0 0 8 int 0 5 在运行栈中申请5个栈空间 9 opr 0 16 从命令行读入输入置于栈顶 10 sto 0 3 将栈顶值存入变量 11 cal 0 2 调用过程 12 lod 0 4 将变量取至栈顶 13 opr 0 14 栈顶值输出至屏幕 14 opr 0 15 换行 15 opr 0 0,RA 12,运行栈,const a=10; var b,c; procedure p; begin c:=b+a; end; begin read(b); call p; write(c); end.,SL:静态链 DL:动态链 RA:返回地址,0,19,PL/0程序到pcode代码的映射,const a=10; var b,c; procedure p; begin c:=b+a; end; begin read(b); while b#0 do begin call p; write(2*c); read(b); end end.,jmp 0 8 jmp 0 2 int 0 3 lod 1 3 lit 0 10 opr 0 2 次栈顶与栈顶相加 sto 1 4 opr 0 0 int 0 5 在运行栈中申请5个栈空间 opr 0 16 从命令行读入输入置于栈顶 sto 0 3 将栈顶值存入变量 lod 0 3 将变量取至栈顶 lit 0 0 将常值0进栈 opr 0 9 次栈顶与栈顶是否不等 jpc 0 24,cal 0 2 调用过程 lit 0 2 常值2进栈 lod 0 4 将变量取至栈顶 opr 0 4 次栈顶与栈顶相乘 opr 0 14 栈顶值输出至屏幕 opr 0 15 换行 opr 0 16 从命令行读取输入 sto 0 3 jmp 0 11 opr 0 0,20,步骤2 PL/0编译程序的总体设计,语法语义分析程序,PL/0源程序,目标程序,21,步骤2 PL/0编译程序的总体设计,其编译过程采用一趟扫描方式 以语法分析程序为核心 词法分析程序和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就调用词法分析程序,而当语法分析正确需要生成相应的目标代码时,则调用代码生成程序。,22,步骤2 PL/0编译程序的总体设计,用表格管理程序建立变量,常量和过程标识符的说明与引用之间的信息联系。 用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错误性质。,23,步骤3 PL/0编译程序词法分析的设计与实现,所需识别的单词 基本字(保留字):BEGIN、 END、 IF、 THEN等 运算符: 如+、-、*、/、:=、#、=、=等 标识符: 用户定义的变量名、常数名、过程名 常数: 如10、25、100等整数 界符: 如,、. 、; 、( 、)等,24,步骤3 PL/0编译程序词法分析的设计与实现,词法分析过程GETSYM所要完成的任务 滤空格 识别保留字 识别标识符 拼数 拼复合词 输出源程序,25,步骤3 PL/0编译程序词法分析的设计与实现,通过三个全程量将识别出的单词信息传递给语法分析程序,SYM,ID,NUM SYM:存放单词的类别,如beginsym, ident, number ID: 存放用户所定义的标识符的值 NUM:存放用户定义的数,26,步骤3 PL/0编译程序词法分析的设计与实现,词法分析程序的设计-使用状态转换图,27,步骤4 PL/0编译程序语法语义分析的设计与实现,语法分析的设计与实现 自顶向下的语法分析 递归子程序法 如何用递归子程序法来实现表达式的语法分析,28,自顶向下的语法分析,VAR A; BEGIN READ(A) END.,29,递归子程序法,递归子程序法:对应每个非终结符语法单元,编一个独立的处理过程(或子程序)。语法分析从读入第一个单词开始由非终结符程序即开始符出发,沿语法描述图箭头所指出的方向进行分析。当遇到非终结符时,则调用相应的处理过程,从语法描述图看也就进入了一个语法单元,再沿当前所进入的语法描述图的箭头方向进行分析,当遇到描述图中是终结符时,则判断当前读入的单词是否与图中的终结符相匹配,若匹配,则执行相应的语义程序(就是翻译程序)。再读取下一个单词继续分析。遇到分支点时将当前的单词与分支点上多个终结符逐个相比较,若都不匹配时可能是进入下一个非终结符语法单位或是出错。,30,如何用递归子程序法来实现表达式的语法分析,表达式的EBNF 表达式=+|-项(+|-)项 项=因子(*|/)因子 因子=标识符|无符号整数|(表达式),31,如何用递归子程序法来实现表达式的语法分析,表达式的实现 procedure expr; begin if sym in plus, minus then begin getsym; term; end else term; while sym in plus, minus do begin getsym; term; end end;,32,如何用递归子程序法来实现表达式的语法分析,项的实现 procedure term; begin factor; while sym in times, slash do begin getsym; factor; end end;,33,如何用递归子程序法来实现表达式的语法分析,因子的实现 procedure factor; begin if sym # ident then begin if sym # number then begin if sym = ( then begin getsym; expr; if sym = ) then getsym else error end else error end end end;,程序 pl0,分程序 block,语句 statement,条件 condition,表达式expression,项 term,因子 factor,PL/0语法调用关系图,编译程序总体流程图,36,程序BLOCK过程的流程图,见课本18页,37,语义分析与处理,说明部分的分析 对每个过程说明的对象(变量,常量和过程)造名字表 填写所在层次,标识符的属性和分配的相对位置。标识符的属性不同时,所需填入的信息也不同。登录信息由ENTER过程完成。 表格管理 过程体的分析,CONST A=35,B=49; VAR C,D,E; PROCEDURE P; VAR G,表格管理,名字 类型 层次/值 地址 存储空间,变量定义语句的处理,if sym=varsym then begin getsym; repeat vardeclaration; while sym=comma do begin getsym; vardeclaration end; if sym=semicolon then getsym else error(5) until symident; end;,40,变量定义语句的处理,procedure vardeclaration; begin if sym=ident then begin enter(variable); getsym end else error(4) end(*vardeclaration*);,41,过程ENTER的实现,procedure enter(k:objects ); begin(*enter object into table*) tx:=tx+1; with tabletx do begin name:=id; kind:=k; case k of constant: begin if numamax then begin error(31); num:=0; end; val:=num end;,variable: begin level:=lev; adr:=dx; dx:=dx+1; end; procedur: level:=lev end end end(*enter*);,42,过程体的分析,从语法上要对语句逐句分析。 当语法正确时就生成相应语句功能的目标代码。 当遇到标识符的引用时就调用POSITION函数查TABLE表,看是否有过正确定义,若已有,则从表中取相应的有关信息,供代码的生成使用。若无定义则错。 例:READ语句的语法语义分析处理 =READ(,),43,READ语句的语法语义分析处理,if sym=readsym then begin getsym; if symlparen then error(34) else repeat getsym; if sym=ident then i:=position(id) else i:=0; if i=0 then error(35) else with tablei do begin gen(opr,0,16); gen(sto,lev-level,adr) end; getsym until symcomma; if symrparen then begin error(33); while not(sym in fsys) do getsym end else getsym end,44,步骤5、 PL/0编译程序代码生成的实现,PL/0语言的代码生成是由过程GEN完成。 GEN有三个参数,分别代表目标代码的功能码,层差和位移量。 gen(opr,0,16); gen(sto,lev-level,adr) 生成的代码顺序放在数组CODE中。 CODE为一维数组,数组元素为记录型数据。每一个记录就是一条目标指令。CX为指令的指针,由0开始顺序增加。实际上目标代码的顺序是内层过程的在前边,主程序的目标代码在最后。,45,步骤5、 PL/0编译程序代码生成的实现,procedure gen(x:fct;y, z:integer); begin if cxcxmax then begin write(program too long); close(fin); writeln; exit end;,with codecx do begin f:=x; l:=y; a:=z end; cx:=cx+1 end (*gen*);,46,步骤6、 PL/0编译程序语法错误处理的实现,对语法错误的两种处理方法: (1) 对于易于校正的错误,如丢了逗号,分号等,指出出错位置,加以校正,继续进行分析 (2) 对于难于校正的错误,给出错误的位置与性质,跳过后面的一些单词,直到下一个可以进行正常语法分析的语法单位。,47,步骤6、 PL/0编译程序语法错误处理的实现,在进入某个语法单位时,调用TEST滤去开始符号前的所有符号。 在语法单位分析结束时,调用TEST滤去当前符号到后继符号之间的所有符号。, TEST TEST,48,开始符号集合与后继符号集合,TEST,SYM在S1中?,打印出错编号n,S1:=S1+S2,SYM在S1中?,GETSYM,返回,Y,Y,N,N,TEST测试过程流程图,50,因子的处理过程,见课本294页 procedure factor(fsys:symse

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论