PL0语言编译器分析实验报告

上传人:夏** 文档编号:561076190 上传时间:2024-02-16 格式:DOCX 页数:9 大小:49.45KB
返回 下载 相关 举报
PL0语言编译器分析实验报告_第1页
第1页 / 共9页
PL0语言编译器分析实验报告_第2页
第2页 / 共9页
PL0语言编译器分析实验报告_第3页
第3页 / 共9页
PL0语言编译器分析实验报告_第4页
第4页 / 共9页
PL0语言编译器分析实验报告_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《PL0语言编译器分析实验报告》由会员分享,可在线阅读,更多相关《PL0语言编译器分析实验报告(9页珍藏版)》请在金锄头文库上搜索。

1、PL/0语言编译器分析实验报告实验目通过阅读与解析一个实际编译器(PL/O语言编译器)的源代码,加深对编 译阶段(包括词法分析、语法分析、语义分析、中间代码生成等)和编译系统 软件结构的理解,并达到提高学生学习兴趣的目的。二实验要求(1) 要求掌握基本的程序设计技巧(C语言)和阅读较大规模程序 源代码 的能力;(2) 理解并掌握编译过程的逻辑阶段及各逻辑阶段的功能;(3) 要求能把握整个系统(PL/0语言编译器)的体系结构,各功能 模块的 功能,各模块之间的接口;(4) 要求能总结出实现编译过程各逻辑阶段功能采用的具体算法与技术。三、实验步骤(1)根据PL/0语言的语法图,理解PL/0语言各级

2、语法单位的结构,掌握 PL/0语言合法程序的结构;从总体上分析整个系统的体系结构、各功能模块的功能、各模块之间的 调用关系、各模块之间的接口;详细分析各子程序和函数的代码结构、程序流程、采用的主要算法及实 现的功能;(4)撰写分析报告,主要内容包括系统结构框图、模块接口、主要算法、各 模块程序流程图等。pl/O语言是pascal语言的一个子集,我们这里分析的pl/O的编译程序包括了 对pl/O语言源程序进行分析处理、编译生成类pcode代码,并在虚拟机上解释运 行生成的类pcode代码的功能。pl/O语言编译程序采用以语法分析为核心、一遍扫描的编译方法。词法分析 和代码生成作为独立的子程序供语

3、法分析程序调用。语法分析的同时,提供了出 错报告和出错恢复的功能。在源程序没有错误编译通过的情况下,调用类pcode 解释程序解释执行生成的类pcode代码。PL/0语言文法的EBNF 表示EBNF表示的符号说明。用左右尖括号括起来的中文字表示语法构造成分,或称语法单位,为非终结符。:=该符号的左部由右部定义,可读作“定义为”。|表示“或”,为左部可由多个右部定义。 花括号表示其内的语法成分可以重复。在不加上下界时可重复0到任意次数,有上下界时为可重复次数的限制。PL/0编译程序过程与函数定义层次结构图pioerrorget syingentestblockpositicon constdec

4、laration var dec lax at ion listcode statementinterpretbasePL/0的解释执行结构PL/O语言目标程序PL/O语言解释执行程序输入数据输出数据PL/0编译程序结构PL/O源程序出错 处理 程代码生成程序表格管理程序目标程序编译程序总体流程图CL启动Y打印错误调用解释过程I NTERPRET 解释执行目标程序源程序中-是否有错误?置初值调用G ET SY M取单词*调用B LO CK过程当前单词是否为源程序结束符 . ?PL/0编译程序的语法分析PL/O编译程序语法、语义分析是整个编译程序设计与实现的核心部分,要求学员努力学习掌握实现技术

5、和方法。现分别说明语法分析实现的主要思想方法和 语义分析的实现。语法分析的任务是识别由词法分析给出的单词符号序列在结构上是否符合 给定的文法规则。PL/O语言的文法规则已在2.1节中给出。本节将以语法图描 述的语法形式为依据,给出语法分析过程的直观思想。PL/0编译程序的语法分析采用了自顶向下的递归子程序法。可用下面简单的PL/O程序为例构造其语法分析树自顶向卜的语法分析VAR砌BEGINREAD(A)ENDVAF.疋标识符色程序语句复合语句BEGIN表达式r项 termr因子factorPL/0编译程序语法分析的设计与实现表达式的递归子程序实现procedure expr;begi nif

6、sym in plus, minus the nbeg in getsym; term;endelse term;while sym in plus, mi nus dobegingetsym; term;endend;因子::二标识符|无符号整数| (表达式) 因子的递归子程序实现procedure factor;beginif sym ide nt the nbeginif sym n umber the nbegi nif sym =( the nbegingetsym;expr;if sym =) the ngetsymelse errorendelse errorendelse ge

7、tsymendelse getsymend;说明部分的分析与处理对每个过程(含主程序)说明的对象(变量,常量和过程)造符号表登录标识符的属性。标识符的属性:种类,所在层次,值和分配的相对位置。登录信息由ENTER过程完成。 常量定义语句的处理语法: 常量说明部分:=const 常量定义,常量定义; 常量定义:= 标识符 = 无符号整数无符号整数:= 数字 数字if sym = con stsym the nbegingetsym; (*获取下一个toke n,正常应为用作常量名的标识符*) repeat (*反复进行常量声明*)constdeclaration; (*声明以当前token为标识

8、符的常量*) while sym = comma do (*如果遇到了逗号则反复声明下一常量*) begi ngetsym; (*获取下一个token,这里正好应该是标识符*) constdeclaration (*声明以当前token为标识符的常量*) end;if sym = semicolon then (*如果常量声明结束,应遇到分号*) getsym (*获取下一个token,为下一轮循环做好准备*)elseerror(*提示5号错误*)until sym ident (*如果遇到非标识符,则常量声明结束*) end;常量说明处理procedure con stdeclarati o

9、n;beginif sym = ide nt the nbegingetsym;if sym in eql, becomes then (* 如果是等号或赋值号 *)if sym = becomes then (*如果是赋值号(常量生明中应该是等号)*) error(1); (* 提示 1 号错误 *)getsym; (*获取下一个token,等号或赋值号后应接上数字*)if sym = number then (*如果的确是数字*) beginenter(constant); (*把这个常量登陆到符号表*) getsym (*获取下一个token,为后面作准备*) endelse error

10、(*如果等号后接的不是数字,提示2号错误*)else error(3)(*如常量标识符后不是等号或赋值号,提示3号错误*)endelse error(4)en d(* con stdeclarati on *);变量定义语句的处理语法: 变量说明部分:二var 标识符,标识符;if sym二varsym the nbegingetsym;repeatvardeclaratio门;(*变量说明处理*)while sym二comma dobegi ngetsym;vardeclarati onend;if sym=semico lon the ngetsymelse error(5)un til

11、symide nt;end;变量说明处理 procedure ardeclarati on;beginif sym = ide nt the nbegi nen ter(variable);getsymendelse error(4)en d(*vardeclarati on *);过程定义语句的处理程序:while sym = procsym do (*循环声明各子过程*)begingetsym; (*获取下一个token,此处正常应为作为过程名的标识符*) if sym = ident then (* 如果 token 确为标识符 *) begi nenter(procedur); (*把这个过程登录到名字表中*)getsym (*获取下一个token,正常情况应为分号*) end elseerror(4); (*否则提示4号错误*)if sym = semicolon then (* 如果当前 token 为分号 *)getsym (*获取下一个token,准备进行语法分析的递归调用*) elseerror(5); (*否则提示5号错误*)

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号