第一范文网 - 专业文章范例文档资料分享平台

new《编译技术》课程实验指导书

来源:用户分享 时间:2020-06-21 本文由沧月哀荒 分享 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

《编译技术》课程实验指导书

实验一 词法分析

一.实验目的

1、 学会针对DFA转换图实现相应的高级语言源程序。 2、 深刻领会状态转换图的含义,逐步理解有限自动机。

3、 掌握手工生成词法分析器的方法,了解词法分析器的内部工作原理。

二.实验内容

TINY计算机语言的编译程序的词法分析部分实现。

从左到右扫描每行该语言源程序的符号,拼成单词,换成统一的内部表示(token)送给语法分析程序。

为了简化程序的编写,有具体的要求如下: (1) 数仅仅是整数。

(2) 空白符仅仅是空格、回车符、制表符。 (3) 代码是自由格式。

(4) 注释应放在花括号之内,并且不允许嵌套

TINY语言的单词

保留字 if then else end repeat until read write

三.实验要求

要求实现编译器的以下功能:

(1) 按规则拼单词,并转换成二元式形式 (2) 删除注释行

特殊符号 + - * / = < { } ; 数 标识符 其他 (一个或更多的字母) (一个或更多的数字) (3) 删除空白符 (空格、回车符、制表符)

(4) 显示源程序,在每行的前面加上行号,并且打印出每行包含的记号的二元形式 (5) 发现并定位错误。 词法分析进行具体的要求:

(1) 记号的二元式形式中种类采用枚举方法定义;其中保留字和特殊字符是每个都

一个种类,标示符自己是一类,数字是一类;单词的属性就是表示的字符串值。

(2) 词法分析的具体功能实现是一个函数GetToken(),每次调用都对剩余的字符串

分析得到一个单词或记号识别其种类,收集该记号的符号串属性,当识别一个单词完毕,采用返回值的形式返回符号的种类,同时采用程序变量的形式提供当前识别出记号的属性值。

(3) 标识符和保留字的词法构成相同,为了更好的实现,把语言的保留字建立一个

表格存储,这样可以把保留字的识别放在标示符之后,用识别出的标示符对比该表格,如果存在该表格中则是保留字,否则是一般标识符。

实验二 递归下降语法分析器设计

一、实验目的

(1)加深对递归下降分析法一种自顶向下的语法分析方法的理解。

(2)根据文法的产生式规则消除左递归,提取公共左因子构造出相应的递归下降分析器。 二、实验内容

根据课堂讲授的形式化算法,编制程序实现递归下降分析器,能对常见的语句进行分析。 三、实验要求

要求实现以下语法的递归下降分析:

示例:

四、实现方法

将要实现语言的上下文无关文法进行检查,消除左递归和左公共因子,从逻辑上检测避免死循环和低效率处理。 采用每个产生式的左边的文法符号对应一个函数或过程的形式,编写程序实现一个递归下降分析器。注意这里的语法分析,是在词法分析的基础上进行的。

实验三 算符优先分析器设计

一、实验目的

(1)掌握算符优先分析法—— 一种自底向上的语法分析方法的思想。 (2)能识别算符优先分析法中的可规约串——最左素短语。 (3)领会算符优先关系表转换成优先函数的方法。 二、实验内容

根据课堂讲授的形式化算法,编制程序实现一个算符优先分析器,能对常见的算术表达式语句进行分析。

已知算符文法G[E]: E→E+E|E-E|E*E|E/E|(E)|-E|id,其优先关系表如下:

三、实验要求

要求实现以下功能: a) 组织算术表达式的输入;

b) 组织算符优先关系表或者优先函数的输入;

c) 若输入的符号串是一个算术表达式语句,则输出一个分析树骨架(既每一步规约用到的最

左素短语),否则输出一个错误信息;

c) 选做:采取相应的技巧,把算术表达式的结果计算出来。 四、实现方法

实现算法,转化成某种高级语言程序,实现一个算符优先分析器。其中要用到分析栈和输入缓冲器,本实验采用的方法是一种自底向上的语法分析方法,所以是在词法分析的基础上进行的。

提示:对于表达式结果的计算,要在算法中引入内部变量来保存结果,另外在分析过程中,除了移进、规约、接受、报错等动作外,还要引入计算的动作。

实验四 LR(k)分析器设计

一、实验目的

(1)掌握下推机这一数学模型的结构和理论,并深刻理解下推自动机在LR分析法中的应用(即LR分析器)。

(2)掌握LR分析法的思想,学会特定分析表的构造方法,利用给出的分析表进行LR分析。 二、实验内容

根据课堂讲授的形式化算法,编制程序实现对以下语法进行自底向上语法分析的LR分析器,设计分析表,对给出的输入语句进行语法分析,判断是否符合相应的文法要求。

Program ? block block ? { stmts } stmts ? stmt stmts | ?

stmt ? id = E ; | while ( bool ) stmt | block bool ? E <= E | E >= E E ? E + T | T T ? id | num

搜索“diyifanwen.net”或“第一范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,第一范文网,提供最新小学教育new《编译技术》课程实验指导书 全文阅读和word下载服务。

new《编译技术》课程实验指导书 .doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/wenku/1089340.html(转载请注明文章来源)
热门推荐
Copyright © 2018-2022 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top