编译原理第二版课后习问题详解.docx
编译原理第二版课后习问题详解(编译原理)课后习题答案第一章第1章引论第1题解释下列术语:1编译程序2源程序3目的程序4编译程序的前端5后端6遍答案:1编译程序:假如源语言为高级语言,目的语言为某台计算机上的汇编语言或机器语言,则此翻译程序称为编译程序。2源程序:源语言编写的程序称为源程序。3目的程序:目的语言书写的程序称为目的程序。4编译程序的前端:它由这样一些阶段组成:这些阶段的工作主要依靠于源语言而与目的机无关。通常前端包括词法分析、语法分析、语义分析和中间代码生成这些阶段,某些优化工作可以在前端做,也包括与前端每个阶段相关的出错处理工作和符号表管理等工作。5后端:指那些依靠于目的机而一般不依靠源语言,只与中间代码有关的那些阶段,即目的代码生成,以及相关出错处理和符号表操作。6遍:是对源程序或其等价的中间语言程序从头到尾扫视并完成规定任务的经过。第2题一个典型的编译程序通常由哪些部分组成?各部分的主要功能是什么?并画出编译程序的总体构造图。答案:一个典型的编译程序通常包含8个组成部分,它们是词法分析程序、语法分析程序、语义分析程序、中间代码生成程序、中间代码优化程序、目的代码生成程序、表格管理程序和错误处理程序。其各部分的主要功能简述如下。词法分析程序:输人源程序,拼单词、检查单词和分析单词,输出单词的机表达形式。语法分析程序:检查源程序中存在的形式语法错误,输出错误处理信息。语义分析程序:进行语义检查和分析语义信息,并把分析的结果保存到各类语义信息表中。中间代码生成程序:根据语义规则,将语法分析程序分析出的语法单位转换成一定形式的中间语言代码,如三元式或四元式。中间代码优化程序:为了产生高质量的目的代码,对中间代码进行等价变换处理。目的代码生成程序:将优化后的中间代码程序转换成目的代码程序。表格管理程序:负责建立、填写和查找等一系列表格工作。表格的作用是记录源程序的各类信息和编译各阶段的进展情况,编译的每个阶段所需信息多数都从表格中读取,产生的中间结果都记录在相应的表格中。能够讲整个编译经过就是造表、查表的工作经过。需要指出的是,这里的“表格管理程序并不意味着它就是一个独立的表格管理模块,而是指编译程序具有的表格管理功能。错误处理程序:处理和校正源程序中存在的词法、语法和语义错误。当编译程序发现源程序中的错误时,错误处理程序负责报告出错的位置和错误性质等信息,同时对发现的错误进行适当的校正修复,目的是使编译程序能够继续向下进行分析和处理。注意:假如问编译程序有哪些主要构成成分,只要回答六部分就能够。假如搞不清楚,就回答八部分。第3题何谓翻译程序、编译程序和解释程序?它们三者之间有何种关系?答案:翻译程序是指将用某种语言编写的程序转换成另一种语言形式的程序的程序,如编译程序和汇编程序等。编译程序是把用高级语言编写的源程序转换加工成与之等价的另一种用低级语言编写的目的程序的翻译程序。解释程序是解释、执行高级语言源程序的程序。解释方式一般分为两种:一种方式是,源程序功能的实现完全由解释程序承当和完成,即每读出源程序的一条语句的第一个单词,则根据这个单词把控制转移到实现这条语句功能的程序部分,该部分负责完成这条语句的功能的实现,完成后返回到解释程序的总控部分再读人下一条语句继续进行解释、执行,如此反复;另一种方式是,一边翻译一边执行,即每读出源程序的一条语句,解释程序就将其翻译成一段机器指令并执行之,然后再读人下一条语句继续进行解释、执行,如此反复。无论是哪种方式,其加工结果都是源程序的执行结果。目前很多解释程序采取上述两种方式的综合实现方案,即先把源程序翻译成较容易解释执行的某种中间代码程序,然后集中解释执行中间代码程序,最后得到运行结果。广义上讲,编译程序和解释程序都属于翻译程序,但它们的翻译方式不同,解释程序是边翻译解释边执行,不产生目的代码,输出源程序的运行结果。而编译程序只负责把源程序翻译成目的程序,输出与源程序等价的目的程序,而目的程序的执行任务由操作系统来完成,即只翻译不执行。第4题对下列错误信息,请指出可能是编译的哪个阶段词法分析、语法分析、语义分析、代码生成报告的。1else没有匹配的if2数组下标越界3使用的函数没有定义4在数中出现非数字字符答案:1语法分析2语义分析3语法分析4词法分析第5题编译程序大致有哪几种开发技术?答案:1自编译:用某一高级语言书写其本身的编译程序。2穿插编译:A机器上的编译程序能产生B机器上的目的代码。3自展:首先确定一个非常简单的核心语言L0,用机器语言或汇编语言书写出它的编译程序T0,再把语言L0扩大到L1,此时L0?L1,并用L0编写L1的编译程序T1,再把语言L1扩大为L2,有L1L2,并用L1编写L2的编译程序T2,如此逐步扩展下去,好似滚雪球一样,直到我们所要求的编译程序。4移植:将A机器上的某高级语言的编译程序搬到B机器上运行。第题计算机执行用高级语言编写的程序有哪些途径?它们之间的主要区别是什么?答案:计算机执行用高级语言编写的程序主要途径有两种,即解释与编译。像Basic之类的语言,属于解释型的高级语言。它们的特点是计算机并不事先对高级语言进行全盘翻译,将其变为机器代码,而是每读入一条高级语句,就用解释器将其翻译为一条机器代码,予以执行,然后再读入下一条高级语句,翻译为机器代码,再执行,如此反复。总而言之,是边翻译边执行。像C,Pascal之类的语言,属于编译型的高级语言。它们的特点是计算机事先对高级语言进行全盘翻译,将其全部变为机器代码,再统一执行,即先翻译,后执行。从速度上看,编译型的高级语言比解释型的高级语言更快。(编译原理)课后习题答案第二章第2章PL/0编译程序的实现第1题PL/0语言允许经过嵌套定义和递归调用,试问它的编译程序怎样解决运行时的存储管理。答案:PL/0语言允许经过嵌套定义和递归调用,它的编译程序在运行时采用了栈式动态存储管理。数组CODE存放的只读目的程序,它在运行时不改变。运行时的数据区S是由解释程序定义的一维整型数组,解释执行时对数据空间S的管理遵循后进先出规则,当每个经过(包括主程序)被调用时,才分配数据空间,退出经过时,则所分配的数据空间被释放。应用动态链和静态链的方式分别解决递归调用和非局部变量的引用问题。第2题若PL/0编译程序运行时的存储分配策略采用栈式动态分配,并用动态链和静态链的方式分别解决递归调用和非局部变量的引用问题,试写出下列程序执行到赋值语句b=10时运行栈的布局示意图。varx,y;procedurep;vara;procedureq;varb;begin(q)b=10;end(q);procedures;varc,d;procedurer;vare,f;begin(r)callq;end(r);begin(s)callr;end(s);begin(p)calls;end(p);begin(main)callp;end(main).答案:程序执行到赋值语句b=10时运行栈的布局示意图为:第3题写出题2中当程序编译到r的经过体时的名字表table的容。namekindlevel/valadrsize答案:题2中当程序编译到r的经过体时的名字表table的容为:namekindlevel/valadrsizexvariable0dxyvariable0dx+1pprocedure0经过p的入口待填5avariable1dxqprocedure1经过q的入口4sprocedure1经过s的入口待填5cvariable2dxdvariable2dxrprocedure2经过r的入口5evariable3dxfvariable3dx+1注意:q和s是并列的经过,所以q定义的变量b被覆盖。第4题指出栈顶指针T,最新活动记录基地址指针B,动态链指针DL,静态链指针SL与返回地址RA的用处。答案:栈顶指针T,最新活动记录基地址指针B,动态链指针DL,静态链指针SL与返回地址RA的用处讲明如下:T:栈顶寄存器T指出了当前栈中最新分配的单元(T也是数组S的下标)。B:基址寄存器,指向每个经过被调用时,在数据区S中给它分配的数据段起始地址,也称基地址。SL:静态链,指向定义该经过的直接外经过或主程序运行时最新数据段的基地址,用以引用非局部包围它的经过变量时,寻找该变量的地址。DL:动态链,指向调用该经过前正在运行经过的数据段基地址,用以经过执行结束释放数据空间时,恢复调用该经过前运行栈的状态。RA:返回地址,记录调用该经过时目的程序的断点,即调用经过指令的下一条指令的地址,用以经过执行结束后返回调用经过时的下一条指令继续执行。在每个经过被调用时在栈顶分配3个联络单元,用以存放SL,DL,RA。第5题PL/0编译程序所产生的目的代码是一种假想栈式计算机的汇编语言,请讲明该汇编语言中下列指令各自的功能和所完成的操作。INT0AOPR00CALLA答案:PL/0编译程序所产生的目的代码中有3条非常重要的特殊指令,这3条_指令在code中的位置和功能以及所完成的操作讲明如下:INT0A在经过目的程序的入口处,开拓A个单元的数据段。A为局部变量的个数+3。OPR00在经过目的程序的出口处,释放数据段退栈,恢复调用该经过前正在运行的经过的数据段基址寄存器B和栈顶寄存器T的值,并将返回地址送到指令地址寄存器P中,以使调用前的程序从断点开场继续执行。CALLA调用经过,完成填写静态链、动态链、返回地址,给出被调用经过的基地址值,送入基址寄存器B中,目的程序的入口地址A的值送指令地址寄存器P中,使指令从A开场执行。第6题给出对PL/0语言作如下功能扩大时的语法图和EBNF的语法描绘。(1)扩大条件语句的功能使其为:if条件then语句else语句(2)扩大repeat语句为:repeat语句;语句until条件答案:对PL/0语言作如下功能扩大时的语法图和EBNF的语法描绘如下:(1)扩大条件语句的语法图为:EBNF的语法描绘为:条件语句:=if条件then语句else语句(2)扩大repeat语句的语法图为:EBNF的语法描绘为:重复语句:=repeat语句;语句until条件(编译原理)课后习题答案第三章第3章文法和语言第1题文法G(A,B,S,a,b,c,P,S)其中P为:SAc|aBAabBbc写出L(GS)的全部元素。答案:L(GS)=abc第2题文法GN为:ND|NDD0|1|2|3|4|5|6|7|8|9GN的语言是什么?答案:GN的语言是V+。V=0,1,2,3,4,5,6,7,8,9N=>ND=>NDD.=>NDDDD.D=>D.D或者:允许0开始的非负整数?第题为只包含数字、加号和减号的表达式,例如9-25,3-1,等构造一个文法。答案:GS:S->S+D|S-D|DD->0|1|2|3|4|5|6|7|8|9第4题已知文法GZ:ZaZb|ab写出L(GZ)的全部元素。答案:Z=>aZb=>aaZbb=>aaa.Z.bbb=>aaa.ab.bbbL(GZ)=anbn|n>=1第5题写一文法,使其语言是偶正整数的集合。要求:(1)允许0打头;