编译原理课程设计报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
武汉纺织大学编译原理课程设计实验报告
学院:数学与计算机
专业:计算机
姓名:
班级:
学号:
constdccl rtrfilri on
VEM'decl OTI
li
-expression to ftn
condition
intet'prct
函数:)
过程或曲数名功能简蔑说咽
pio主程序
error出错处理*打印出错位苫和错误编码
gdsym词济分祈,煤取一t单詞
秦理空格,读収「牛字苻
生止目标优码.井送入目林序区test義试当前单诵符是否合法
block务析程启噩理讨稈
enter
pnwfiion(画
慰)
查找标识符在名字丢中肿位置constdeclaratiDn常虽定克牲理
TardeclaratiDn变虽主兗魁理
listccxle列出目掃诧码詩单
statemeiit
espressiiMi盂这式处理
tenn
factor
crnidiiicn条件辿埋
iiiteipret刖日标吒码购解释执厅程序
通过静蠱穆求;L数据仅的宰地圳编译原理课设报告
一、实验目的
加强对编译程序的整体认识和了解,巩固《编译原理》课程所学知识。通过本次课程设计掌握编译程序调试技巧和设计编译程序一般的原则,加深对词法分析、语法分析、语义分
析等编译阶段及实用编译系统的认识。使学生能将编译理论与实际应用结合起来,提高学生软件开发的能力。
二、实验内容
1)仔细阅读PL/O编译程序文本(编译原理(第二版)张素琴吕映芝蒋维杜戴桂兰主编清华大学出版社),并上机调试通过。
2)对PL/0语言进行下列扩充
(1)扩充一维整型数组。
扩充var数组:VAR <数组标识名>(<下界>:<上界>)〈下界〉和〈上界〉可用常量标识名。
(2)扩充条件语句的功能使其为:IF<条件>THEN齬句>[ELSE语句>]
(3)增加repeat重复语句:
REPEAT<语句>{;<语句>}UNTIL<条件>
可根据自己具体情况从中选择2个以上题目进行扩充。
三、实验原理
PL/0语言可以看成PASCALS言的子集,它的编译程序是一个编译解释执行系统。PL/0的目标程序为假想栈式计算机的汇编语言,与具体计算机无关。
PL/0的编译程序和目标程序的解释执行程序都是用PASCAL语言书写的,因此PL/0语
言可在配备PASCAL语言的任何机器上实现。其编译过程采用一趟扫描方式,以语法分析程序为核心,词法分析和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就调用词法分析程序,而当语法分析正确需要生成相应的目标代码时,则调用代码生成程序。
用表格管理程序建立变量、常量和过程表示符的说明与引用之间的信息联系。
当源程序编译正确时,PL/0编译程序自动调用解释执行程序,对目标代码进行解释执
行,并按用户程序的要求输入数据和输出运行结果。
编译原理
error
test
隔麺功能说阴孟:
四、实验分析
PL/O语言编译程序采用以语法分析为核心、一遍扫描的编译方法。词法分析和代码生成作为独立的子程序供语法分析程序调用。语法分析的同时,提供了出错报告和出错恢复
的功能。在源程序没有错误编译通过的情况下,调用类PCODE解释程序解释执行生成的类PCODE代码。
词法分析子程序分析:
词法分析子程序名为GETSYM功能是从源程序中读出一个单词符号(TOTAKEN,把它
的信息放入全局变量SYM ID和NUM中,字符变量放入CH中,语法分析器需要单词时,
直接从这三个变量中获得。Getch过程通过反复调用Getch子过程从源程序过获取字符,并
把它们拼成单词。GETCH过程中使用了行缓冲区技术以提高程序运行效率。
词法分析器的分析过程:调用GETSYM时,它通过GETCH过程从源程序中获得一个字
符。如果这个字符是字母,则继续获取字符或数字,最终可以拼成一个单词,查保留字表,如果查到为保留字,则把SYM变量赋成相应的保留字类型值;如果没有查到,则这个单词
应是一个用户自定义的标识符(可能是变量名、常量名或是过程的名字),把SYM置为IDENT,
把这个单词存入ID变量。查保留字表时使用了二分法查找以提高效率。如果Getch获得的字符是数字,则继续用Getch获取数字,并把它们拼成一个整数或实数,然后把SYM置为INTEGER或REAL并把拼成的数值放入NUM变量。如果识别出其它合法的符号(比如:赋值号、大于号、小于等于号等),则把SYM则成相应的类型。如果遇到不合法的字符,把SYM 置成NUL。
语法分析子程序分析:
语法分析子程序采用了自顶向下的递归子程序法,语法分析同时也根据程序的语义生成
相应三元代码,并提供了出错处理的机制。语法分析主要由分程序分析过程(BLOCK、参
数变量分析过程(ParaDeclaration、、参数变量处理过程(ParaGetSub)、数组处理过程(ParaGetSub)、常量定义分析过程(ConstDeclaration、、变量定义分析过程(Vardeclaration、、语句分析过程(Stateme nt )、表达式处理过程(Expressio n)、项处理过程(Term)、因子处理过程(Factor、和条件处理过程(Condition、构成。这些过程在结构上构成一个嵌套的层次结构。除此之外,还有出错报告过程(Error)、代码生成过程(Gen)、测试单词合法性及出错恢复过程(Test)、登录名字表过程(Enter、、查询名字表函数(Position)以及列出类PCODE 代码过程(Listcode、作过语法分析的辅助过程。
由PL/0的语法图可知:一个完整的PL/0程序是由分程序和句号构成的。因此,本编译
程序在运行的时候,通过主程序中调用分程序处理过程block来分析分程序部分(分程序分
析过程中还可能会递归调用block过程),然后,判断最后读入的符号是否为句号。如果是
句号且分程序分析中未出错,则是一个合法的PL/0程序,可以运行生成的代码,否则就说
明源PL/0程序是不合法的,输出出错提示即可。
if-then-else语句的处理:
按if语句的语法,首先调用逻辑表达式处理过程处理if语句的条件,把相应的真假值