编译原理概念题

1.一个典型的编译系统通常由哪几部分组成?各个部分的主要功能是什么?
答:词法分析、语法分析、语义分析与中间代码生成、代码优化、目标代码生成,以及表格处理、出错处理 七个部分。
语法阶段:对构成源程序的字符串从左到右进行扫描和分解,根据语言的语法规则,识别出一个一个具有独立意义的单词(也称单词符号,简称符号)。
语法分析:检查各种语法单位在语法结构上的正确性。
语义分析与中间代码生成—对语言的各种语法单位赋予具体的意义。
代码优化:对前阶段产生的中间代码进行等价变换或改造,以期获得更为高效的,即省时间和空间的目标代码
目标代码生成:将中间代码变换成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码。
表格处理:登记各个阶段需要构造、查找、修改或存取信息于表格中。
出错处理:在编译过程中具有查错能力,并能准确地报告错误的种类及其出错位置,以便用户查找和纠错。

2.简述乔姆斯基是如何对文法进行分类的?
答:乔姆斯基把文法分成四种类型,即0型、1型、2型、3型。划分的依据是对文法中的规则施加不同的限制。0型文法叫无限制文法,1型文法叫上下文有关文法,2型文法叫上下文无关文法,3型文法叫正规文法。

3.数组的内情向量包含哪些内容?
答:在编译程序对数组说明进行语义处理时,须把数组的类型type、维数n、各维的上、下界1k,uk等有关信息记录下来。此外,如果数组是常界的,还可将各维的界差dk以及计算数组元素地址的常量C记录下来。为了便于引用,通常是把上述信息存放于数组相应的“内情向量”之中,对数组内情向量的访问,可通过数组在符号表中的相应登记项的ADDR域以间接寻址方式进行(即将其ADDR域作为指针用于存放内情向量的首地址)。

4.简述语法制导翻译的基本思想?
答:一个句子的语义翻译过程与语法分析过程同时进行。在文法中,文法符号有明确的意义,文法符号之间有确定的语义关系。属性描述语义信息,语义规则描述属性间的关系,将语义规则与语法规则相结合,在语法分析的过程中计算语义属性值。

5.代码优化的目的是什么?中间代码优化有哪三类优化方式?
答:代码优化是为了提高目标代码的质量而引入的,不是必须的,没有代码优化编译程序同样生成目标代码。
三种级别:局部优化、循环优化、全局优化

符号表相关(作用、组织形式、策略)

  • 符号表的组织方式有哪几种?

答:一个编译程序对符号表的总体组织有三种选择,①把属性种类完全相同的那些符号组织在一起,构造出表项是分别为等长的多个符号表 ②把所有语言中的符号都组织在一张符号表中,组成一张包括了所有属性的庞大的符号表。 ③折衷方式是根据符号属性相似程度分类组织成若干张表,每张表中记录的符号都有比较多的相同属性。
- 在整个编译期间,对于符号表的操作有哪些?

答:大致可分为五类:
1)对给定名字,查询此名是否已在表中
2)往表中填入一个新的名字
3)对给定名字,访问它的某些信息
4)对给定名字,往表中填写或更新它的某些信息
5)删除一个或一组无用的项

- 符号表的作用有哪些?

答:在编译程序中符号表用来存放语言程序中出现的有关标识符的属性信息,这些信息集中反映了标识符的语义特征属性,起主要作用是:①收集符号属性 ②上下文语义的合法性检查的依据 ③作为目标代码生成阶段地址分配的依据

  • 符号表中的信息栏中登记了每个名字的属性和特征等有关信息,如类型、种属、所占单元大小、地址等等。

运行时存储管理
答:分程序结构的栈式存储管理中的活动记录包括哪些内容?
临时工作单元、局部变量、保存机器状态、存取链、控制链、实参,也称形式单元、返回地址、保存该被调过程中返回后的地址。

(1)常用的两种动态存贮分配办法是栈式动态分配和堆式动态分配。

代码优化(局部优化、优化的意义)
答:局部优化是局限于一种基本块范围内的一种优化。
优化:对程序进行各种等价变换,使得从变换后的程序出发,能产生更有效的目标代码。

(2)代码优化的主要目标是如何提高目标程序的运行速度和如何减少目标程序运行时所需的空间。

编译原理》课后习答案第一章 第 1 章引论 第 1  解释下列术语: (1)编译程序 (2)源程序 (3)目标程序 (4)编译程序的前端 (5)后端 (6)遍 答案: (1) 编译程序:如果源语言为高级语言,目标语言为某台计算机上的汇编语言或机器语 言,则此翻译程序称为编译程序。 (2) 源程序:源语言编写的程序称为源程序。 (3) 目标程序:目标语言书写的程序称为目标程序。 (4) 编译程序的前端:它由这样一些阶段组成:这些阶段的工作主要依赖于源语言而与 目标机无关。通常前端包括词法分析、语法分析、语义分析和中间代码生成这些阶 段,某些优化工作也可在前端做,也包括与前端每个阶段相关的出错处理工作和符 号表管理等工作。 (5) 后端:指那些依赖于目标机而一般不依赖源语言,只与中间代码有关的那些阶段, 即目标代码生成,以及相关出错处理和符号表操作。 (6) 遍:是对源程序或其等价的中间语言程序从头到尾扫视并完成规定任务的过程。 第 2  一个典型的编译程序通常由哪些部分组成?各部分的主要功能是什么?并画出编译程 序的总体结构图。 答案: 一个典型的编译程序通常包含 8 个组成部分,它们是词法分析程序、语法分析程序、语 义分析程序、中间代码生成程序、中间代码优化程序、目标代码生成程序、表格管理程序和 错误处理程序。其各部分的主要功能简述如下。 词法分析程序:输人源程序,拼单词、检查单词和分析单词,输出单词的机内表达形式。 语法分析程序:检查源程序中存在的形式语法错误,输出错误处理信息。 语义分析程序:进行语义检查和分析语义信息,并把分析的结果保存到各类语义信息表 中。 中间代码生成程序:按照语义规则,将语法分析程序分析出的语法单位转换成一定形式 的中间语言代码,如三元式或四元式。 中间代码优化程序:为了产生高质量的目标代码,对中间代码进行等价变换处理。 盛威网(www.snwei.com)专业的计算机学习网站1 《编译原理》课后习答案第一章 目标代码生成程序:将优化后的中间代码程序转换成目标代码程序。 表格管理程序:负责建立、填写和查找等一系列表格工作。表格的作用是记录源程序的 各类信息和编译各阶段的进展情况,编译的每个阶段所需信息多数都从表格中读取,产生的 中间结果都记录在相应的表格中。可以说整个编译过程就是造表、查表的工作过程。需要指 出的是,这里的“表格管理程序”并不意味着它就是一个独立的表格管理模块,而是指编译 程序具有的表格管理功能。 错误处理程序:处理和校正源程序中存在的词法、语法和语义错误。当编译程序发现源 程序中的错误时,错误处理程序负责报告出错的位置和错误性质等信息,同时对发现的错误 进行适当的校正(修复),目的是使编译程序能够继续向下进行分析和处理。 注意:如果问编译程序有哪些主要构成成分,只要回答六部分就可以。如果搞不清楚, 就回答八部分。 第 3  何谓翻译程序、编译程序和解释程序?它们三者之间有何种关系? 答案: 翻译程序是指将用某种语言编写的程序转换成另一种语言形式的程序的程序,如编译程 序和汇编程序等。 编译程序是把用高级语言编写的源程序转换(加工)成与之等价的另一种用低级语言编 写的目标程序的翻译程序。 解释程序是解释、执行高级语言源程序的程序。解释方式一般分为两种:一种方式是, 源程序功能的实现完全由解释程序承担和完成,即每读出源程序的一条语句的第一个单词, 则依据这个单词把控制转移到实现这条语句功能的程序部分,该部分负责完成这条语句的功 能的实现,完成后返回到解释程序的总控部分再读人下一条语句继续进行解释、执行,如此 反复;另一种方式是,一边翻译一边执行,即每读出源程序的一条语句,解释程序就将其翻 译成一段机器指令并执行之,然后再读人下一条语句继续进行解释、执行,如此反复。无论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Next---YOLO

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值