编译原理(第二版~)张素琴清华大学-答案~详解.doc
《编译原理(第二版~)张素琴清华大学-答案~详解.doc》由会员分享,可在线阅读,更多相关《编译原理(第二版~)张素琴清华大学-答案~详解.doc(169页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、编译原理课后习题答案第一章 第 1 章 引论 第1题 解释 下列 术语 : (1)编译程序 (2)源程序 (3)目标程序 (4)编译程序的前端 ( 5) 后 端 (6)遍 答案: (1) 编译程序:如果源语言为高级语言,目标语言为某台计算机上的汇编语言或机器语 言,则此翻译程序称为编译程序。 (2) 源程序:源语言编写的程序称为源程序。 (3) 目标程序:目标语言书写的程序称为目标程序。 (4) 编译程序的前端:它由这样一些阶段组成:这些阶段的工作主要依赖于源语言而与 目标机无关。通常前端包括词法分析、语法分析、语义分析和中间代码生成这些阶 段,某些优化工作也可在前端做,也包括与前端每个阶段相
2、关的出错处理工作和符 号表管理等工作。 (5) 后端:指那些依赖于目标机而一般不依赖源语言,只与中间代码有关的那些阶段, 即目标代码生成,以及相关出错处理和符号表操作。 (6) 遍:是对源程序或其等价的中间语言程序从头到尾扫视并完成规定任务的过程。 第2题 一个典型的编译程序通常由哪些部分组成?各部分的主要功能是什么?并画出编译程 序的总 体结 构 图。 答案: 一个典型的编译程序通常包含 8 个组成部分,它们是词法分析程序、语法分析程序、语 义分析程序、 中间代码生成程序、中间代码优化程序、目标代码生成程序、表格管理程序和 错误处理程序。其各部分的主要功能简述如下。 词法分析程序:输人源程序
3、,拼单词、检查单词和分析单词,输出单词的机内表达形式。 语法分析程序:检查源程序中存在的形式语法错误,输出错误处理信息。 语义分析程序:进行语义检查和分析语义信息,并把分析的结果保存到各类语义信息表 中。 中间代码生成程序:按照语义规则,将语法分析程序分析出的语法单位转换成一定形式 的中间语言代码,如三元式或四元式。 中间代码优化程序:为了产生高质量的目标代码,对中间代码进行等价变换处理。 盛威网()专业的计算机学习网站 1编译原理课后习题答案第一章 目标代码生成程序:将优化后的中间代码程序转换成目标代码程序。 表格管理程序:负责建立、填写和查找等一系列表格工作。表格的作用是记录源程序的 各类
4、信息和编译各阶段的进展情况,编译的每个阶段所需信息多数都从表格中读取,产生的 中间结果都记录 在相应的表格中。可以说整个编译过程就是造表、查表的工作过程。需要指 出的是,这里的“表格管理程序“并 不意味着它就是一个独立的表格管理模块,而是指编译 程序具有的表格管理功能。 错误处理程序:处理和校正源程序中存在的词法、语法和语义错误。当编译程序发现源 程序中的错误时, 错误处理程序负责报告出错的位置和错误性质等信息,同时对发现的错误 进行适当的校正(修复) ,目的是使编译程序能够继续向下进行分析和处理。 注意:如果问编译程序有哪些主要构成成分,只要回答六部分就可以。如果搞不清楚, 就回答 八部 分
5、 。 第3题 何谓翻译程序、编译程序和解释程序?它们三者之间有何种关系? 答案: 翻译程序是指将用某种语言编写的程序转换成另一种语言形式的程序的程序, 如编译程 序和汇编程序等。 编译程序是把用高级语言编写的源程序转换(加工)成与之等价的另一种用低级语言编 写的目标程序的翻译程序。 解释程序是解释、执行高级语言源程序的程序。解释方式一般分为两种:一种方式是, 源程序功能的实现 完全由解释程序承担和完成,即每读出源程序的一条语句的第一个单词, 则依据这个单词把控制转移到实现这条语句功能的程序部分, 该部分负责完成这条语句的功 能的实现,完成 后返回到解释程序的总控部分再读人下一条语句继续进行解释
6、、执行,如此 反复;另一种方式是,一边翻译一 边执行,即每读出源程序的一条语句,解释程序就将其翻 译成一段机器指令并执行之,然后再读人下一条语 句继续进行解释、执行,如此反复。无论 盛威网()专业的计算机学习网站 2编译原理课后习题答案第一章 是哪种方式,其加工结果都是源程序的执行结果。目前很多解释程序采取上述两种方式的综 合实现方案,即 先把源程序翻译成较容易解释执行的某种中间代码程序,然后集中解释执行 中间代码程序,最后得到运行结果。 广义上讲,编译程序和解释程序都属于翻译程序,但它们的翻译方式不同,解释程序是 边翻译(解释)边 执行,不产生目标代码,输出源程序的运行结果。而编译程序只负责
7、把源 程序翻译成目标程序,输出与源程 序等价的目标程序,而目标程序的执行任务由操作系统来 完成,即只翻译不执行。 第4题 对下列错误信息,请指出可能是编译的哪个阶段(词法分析、语法分析、语义分析、 代码生成)报告的。 (1) else 没有匹配的 if (2) 数组下标越界 (3) 使用的函数没有定义 (4) 在数中出现非数字字符 答案: (1) (2) (3) (4) 第5题 语法分析 语义分析 语法分析 词法分析 编译程序大致有哪几种开发技术? 答案: (1)自编译:用某一高级语言书写其本身的编译程序。 (2)交叉编译:A 机器上的编译程序能产生 B 机器上的目标代码。 (3)自展:首先确
8、定一个非常简单的核心语言 L0,用机器语言或汇编语言书写出它的编译 程序 T0,再把语言 L0 扩充到 L1,此时 L0 L1 ,并用 L0 编写 L1 的编译程序 T1,再把语 言 L1 扩充为 L2,有 L1 L2 ,并用 L1 编写 L2 的编译程序 T2,如此逐步扩展下去, 好似滚雪球一样,直到我们所要求的编译程序。 (4)移植:将 A 机器上的某高级语言的编译程序搬到 B 机器上运行。 盛威网()专业的计算机学习网站 3编译原理课后习题答案第一章 第题 计算机执行用高级语言编写的程序有哪些途径?它们之间的主要区别是什么? 答案: 计算机执行用高级语言编写的程序主要途径有两种,即解释与
9、编译。 像 Basic 之类的语言,属于解释型的高级语言。它们的特点是计算机并不事先对高级语 言进行全盘翻译,将其变为机器代码,而是每读入一条高级语句,就用解释器将其翻译为一 条机器代码,予以执行,然后再读入下一条高级语句,翻译为机器代码,再执行,如此反复。 总而言之,是边翻译边执行。 像 C,Pascal 之类的语言,属于编译型的高级语言。它们的特点是计算机事先对高级语 言进行全盘翻译,将其全部变为机器代码,再统一执行,即先翻译,后执行。从速度上看, 编译型的高级语言比解释型的高级语言更快。 盛威网()专业的计算机学习网站 4编译原理课后习题答案第二章 第 2 章 PL/0 编译程序的实现
10、第1题 PL/0 语言允许过程嵌套定义和递归调用,试问它的编译程序如何解决运行时的存储管 理。 答案: PL/0 语言允许过程嵌套定义和递归调用,它的编译程序在运行时采用了栈式动态存储 管理。(数组 CODE 存放的只读目标程序,它在运行时不改变。)运行时的数据区 S 是由 解释程序定义 的一维整型数组,解释执行时对数据空间 S 的管理遵循后进先出规则,当每 个过程(包括主程序)被调用 时,才分配数据空间,退出过程时,则所分配的数据空间被释放。 应用动态链和静态链的方式分别解决递归调用和非局部变量的引用问题。 第2题 若 PL/0 编译程序运行时的存储分配策略采用栈式动态分配,并用动态链和静态
11、链的方 式分别解决 递归调用和非局部变量的引用问题,试写出下列程序执行到赋值语句 b=10 时 运行栈的布局示意图。 var x,y; procedure p; var a; procedure q; var b; begin (q) b=10; end (q); procedure s; var c,d; procedure r; var e,f; begin (r) call q; end (r); begin (s) call r; end (s); begin (p) call s; 盛威网()专业的计算机学习网站 1编译原理课后习题答案第二章 end (p); begin (main
12、) call p; end (main). 答案: 程序执行到赋值语句 b=10 时运行栈的布局示意图为: 第3题 写出题 2 中当程序编译到 r 的过程体时的名字表 table 的内容。 name kind level/val adr size 答案: 题 2 中当程序编译到 r 的过程体时的名字表 table 的内容为: name kind level/val adr size xvariable 0dx yvariable 0dx+1 pprocedure 0过程 p 的入口(待填) 5盛威网()专业的计算机学习网站 2编译原理课后习题答案第二章 avariable 1dx qproce
13、dure 1过程 q 的入口 4sprocedure 1过程 s 的入口(待填) 5cvariable 2dx dvariable 2dx rprocedure 2过程 r 的入口 5evariable 3dx fvariable 3dx+1 注意:q 和 s 是并列的过程,所以 q 定义的变量 b 被覆盖。 第4题 指出栈顶指针 T,最新活动记录基地址指针 B,动态链指针 DL,静态链指针 SL 与返 回地址 RA 的用途。 答案: 栈顶指针 T,最新活动记录基地址指针 B,动态链指针 DL,静态链指针 SL 与返回地址 RA 的用途说明如下: T: 栈顶寄存器 T 指出了当前栈中最新分配的
14、单元(T 也是数组 S 的下标)。 B:基址寄存器,指向每个过程被调用时,在数据区 S 中给它分配的数据段起 始 地址, 也 称 基 地 址 。 SL: 静态链,指向定义该过程的直接外过程(或主程序)运行时最新数据段的基地址, 用以引用非局部(包围它的过程)变量时,寻找该变量的地址。 DL: 动态链,指向调用该过程前正在运行过程的数据段基地址,用以过程执行结束释 放数据空间时,恢复调用该过程前运行栈的状态。 RA: 返回地址,记录调用该过程时目标程序的断点,即调用过程指令的下一条指令的 地址,用以过程执行结束后返回调用过程时的下一条指令继续执行。 在每个过程被调用时在栈顶分配 3 个联系单元,
15、用以存放 SL,DL, RA。 第5题 PL/0 编译程序所产生的目标代码是一种假想栈式计算机的汇编语言,请说明该汇编语 言中下列指令各自的功能和所完成的操作。 () INT 0 A () OPR 0 0 () CAL L A 答案: PL/0 编译程序所产生的目标代码中有 3 条非常重要的特殊指令,这 3 条指令在 code 中 的位置和功能以及所完成的操作说明如下: 盛威网()专业的计算机学习网站 3编译原理课后习题答案第二章 INT 0 A 在过程目标程序的入口处,开辟 A 个单元的数据段。A 为局部变量的个数+3。 OPR 0 0 在过程目标程序的出口处,释放数据段(退栈),恢复调用该
16、过程前正在运行的过程的 数据段基址寄存器 B 和栈顶寄存器 T 的值,并将返回地址送到指令地址寄存器 P 中,以使 调用前的程序从断点开始继续执行。 CAL L A 调用过程,完成填写静态链、动态链、返回地址,给出被调用过程的基地址值,送入基 址寄存器 B 中,目标程序的入口地址 A 的值送指令地址寄存器 P 中,使指令从 A 开始执行。 第6题 给出对 PL/0 语言作如下功能扩充时的语法图和 EBNF 的语法描述。 (1) 扩充条件语句的功能使其为: if条件then语句else语句 (2) 扩充 repeat 语句为: repeat语句; 语句until条件 答案: 对 PL/0 语言作
17、如下功能扩充时的语法图和 EBNF 的语法描述如下: (1) 扩充条件语句的语法图为: EBNF 的语法描述为: 条件语句:= if条件then语句else语句 (2) 扩充 repeat 语句的语法图为: EBNF 的语法描述为: 重复语句:= repeat语句;语句until条件 盛威网()专业的计算机学习网站 4编译原理课后习题答案第三章 第 3章 文 法 和 语 言 第1题 文法 G(A,B,S,a,b,c,P,S)其中 P 为: SAc|aB Aab Bbc 写出 L(GS)的全部元素。 答案: L(GS)=abc 第2题 文法 GN为: ND|ND D0|1|2|3|4|5|6|7
18、|8|9 GN的语 言是什么? 答案: GN的语言是 V+。V=0,1,2,3,4,5,6,7,8,9 N=ND=NDD. =NDDDD.D=D.D 或者:允许 0 开头的非负整数? 第题 为只包含数字、加号和减号的表达式,例如 9-25,3-1,等构造一个文法。 答案: GS: S-S+D|S-D|D D-0|1|2|3|4|5|6|7|8|9 第4题 已知文法 GZ: ZaZb|ab 写出 L(GZ)的全部元素。 盛威网()专业的计算机学习网站 1编译原理课后习题答案第三章 答案: Z=aZb=aaZbb=aaa.Z.bbb= aaa.ab.bbb L(GZ)=anbn|n=1 第5题 写
19、一文法,使其语言是偶正整数的集合。 要求: (1) 允许 0 打头; (2)不允许 0 打头。 答案: (1)允许 0 开头的偶正整数集合的文法 ENT|D TNT|D ND|1|3|5|7|9 D0|2|4|6|8 (2)不允许 0 开头的偶正整数集合的文法 ENT|D TFT|G ND|1|3|5|7|9 D2|4|6|8 FN|0 GD|0 第6题 已知文法 G: := :=* :=()i 试给出下述表达式的推导及语法树。 ()i+(i+i) ()i+i*i 盛威网()专业的计算机学习网站 2编译原理课后习题答案第三章 答案: (5) = = =() =() =() =(i) =(i)
20、+ =(i) =(ii) =(ii) =(ii) =i(ii) i(i+)i(6) = =* =*i =*i =i*i =i*i =i*i =ii*i i+i* i盛威网()专业的计算机学习网站 3编译原理课后习题答案第三章 第7题 证明下述文法 G表达式是二义的。 表达式=a|(表达式)|表达式 运算符 表 达 式 运算符=+|-|*|/ 答案: 可为句子 a+a*a 构造两个不同的最右推导: 最右推导 1 表达式 表达式 运算符 达式 表 表达式 运算符a 表达式* a 表达式 运算符 达式* a 表 表达式 运算符a * a 表达式+ a * a a+a*a 最右推导 2 表达式 表达式
21、 运算符 达式 表 表达式 运算符 达式 表 运 算 符 表 达 式 表达式 运算符 达式 表 运算符 a 表达式 运算符 达式 * a 表 表达式 运算符a * a 表达式+ a * a a+a*a 盛威网()专业的计算机学习网站 4编译原理课后习题答案第三章 第8题 文法 GS为: SAc|aB Aab Bbc 该文法是否为二义的?为什么? 答案: 对于串 abc (1)S=Ac=abc (2)S=aB=abc 即存在两不同的最右推导。所以,该文法是二义的。 或者: 对输入字符串 abc,能构造两棵不同的语法树,所以它是二义的。 SSaBAcbc ab第9题 考虑下面上下文无关文法: SS
22、S*|SS+|a (1)表明通过此文法如何生成串 aa+a*,并为该串构造语法树。 (2)GS的语言是什么? SSS*答案: SS+a (1)此文法生成串 aa+a*的最右推导如下 S=SS*=SS*=Sa*=SS+a*=Sa+a*=aa+a* aa(2)该文法生成的语言是:*和+的后缀表达式,即逆波兰式。 盛威网()专业的计算机学习网站 5编译原理课后习题答案第三章 第 10 题 文法 SS(S)S| (1) 生成的语言是什么? (2) 该文法是二义的吗?说明理由。 答案: () 嵌套的括号 () 是二义的,因为对于() ()可以构造两棵不同的语法树。 第 11 题 令文法 GE为: ET|
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 第二 张素琴 清华大学 答案 详解
限制150内