编译原理考题

编译原理考题

ID:42760099

大小:204.51 KB

页数:4页

时间:2019-09-22

编译原理考题_第1页
编译原理考题_第2页
编译原理考题_第3页
编译原理考题_第4页
资源描述:

《编译原理考题》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、1、编译原理结构框图2、一个典型的编译程序通常由哪些部分组成?各部分的主要功能是什么?答:一个典型的编译程序通常包含8个组成部分,它们是词法分析程序、语法分析程序、语义分析程序、中间代码生成程序、中间代码优化程序、目标代码生成程序、表格管理程序和错误处理程序。其各部分的主要功能简述如下。词法分析程序:从左到右扫描源程序,识别单词及其相关属性语法分析程序:分析源程序的结构,判别它是否为相应程序设计语言中的一个合法程序语义分析程序:审查源程序有无语义错误,为代码生成阶段收集类型信息 中间代码生成程序:将源程序变成一种内部 表示形式。代码优化程序:对中间代码进行变换或改

2、造,使生成的代码更为高效目标代码生成程序:把中间代码变成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码表格管理程序:负责建立、填写和查找等一系列表格工作。错误处理程序:处理和校正源程序中存在的词法、语法和语义错误。注意:如果问编译程序有哪些主要构成成分,只要回答六部分就可以。如果搞不清楚,就回答八部分。3、什么是解释程序?它与翻译程序的主要不同是什么?答:解释程序接受某个语言的程序并立即运行这个源程序。它的工作模式是一个个的获取、分析并执行源程序语句,一旦第一个语句分析结束,源程序便开始运行并且生成结果,它特别适合程序员交互的工作情况,而编译程序是一个

3、语言处理程序,它把一个高级语言程序翻译成某个机器的汇编或二进制代码程序,这个二进制代码程序在机器上运行以生成结果。它们的主要不同在于:解释程序是边解释边执行,解释程序运行结束即可得到该程序的运行结果,而编译程序只是把源程序翻译成汇编或者二进制程序,这个程序再执行才能得到程序的运行结构。1、符号和符号串a)字母表:字母表是元素的非空有穷集合,我们把字母表的中的元素称为符号,因此字母表也称为符号集b)符号串:由字母表中的符号组成的任何有穷序列称为符号串,字母表A={a,b,c}上的符号串有:a,b,c,ab,aaca.2、一个的4个组成部分文法G定义为四元组(VN,V

4、T,P,S)VN:非终结符集VT:终结符集P:规则的集合S:识别符或开始符3、典型例题及解答证明文法G=({E,O},{(,),+,*,v,d},P,E)是二义的E→EOE

5、(E)

6、v

7、dO→+

8、*解:对于句子v*v+d的语法树不止一棵,如图3.7和图3.8所以该文法是二义的4、写一文法,使其语言是偶正整数的集合。 要求: (1) 允许0打头;  (2)不允许0打头。答案:(1)允许0开头的偶正整数集合的文法   E→NT

9、D   T→NT

10、D N→D

11、1

12、3

13、5

14、7

15、9   D→0

16、2

17、4

18、6

19、8(2)不允许0开头的偶正整数集合的文法   E→NT

20、D    T

21、→FT

22、G    N→D

23、1

24、3

25、5

26、7

27、9   D→2

28、4

29、6

30、8   F→N

31、0   G→D

32、0 1、给出生成下述语言的三型文法:2、解释1、

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。