编译原理复习题(经典). 下载本文

内容发布更新时间 : 2025/1/11 3:17:17星期一 下面是文章的全部内容请认真阅读。

编译原理复习题

一、是非题

1.计算机高级语言翻译成低级语言只有解释一种方式。() 3.每个文法都能改写为 LL(1) 文法。 ()

4.算符优先关系表不一定存在对应的优先函数。 () 5.LR分析方法是自顶向下语法分析方法。 ()

6.“ 用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行 ”这种说法。() 7.一个句型的句柄一定是文法某产生式的右部。 ()

8.仅考虑一个基本块,不能确定一个赋值是否真是无用的。 ()

9.在中间代码优化中循环上的优化主要有不变表达式外提和削减运算强度。 ( ) 10.对于数据空间的存贮分配,FORTRAN采用动态贮存分配策略。()

11.甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全相同。( ) 12.递归下降分析法是自顶向下分析方法。( )

13.产生式是用于定义词法成分 的一种书写规则。 () 14.在 SLR(1)分析法的名称中,S的含义是简单的。() 15.综合属性是用于 “ 自上而下 ” 传递信息。( )

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

17.程序语言的语言处理程序是一种应用软件。 ()

18.解释程序适用于 COBOL 和 FORTRAN 语言。 () 19.一个 LL(l)文法一定是无二义的。 ()

20.正规文法产生的语言都可以用上下文无关文法来描述。 ()

21.一张转换图只包含有限个状态,其中有一个被认为是初态,最多只有一个终态。 () 22.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。 () 22.逆波兰法表示的表达式亦称后缀式 。 ( )

23.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义的。 ( ) 24.数组元素的地址计算与数组的存储方式有关。() 25.算符优先关系表不一定存在对应的优先函数。 () 26.编译程序是对高级语言程序的解释执行。( )

27.一个有限状态自动机中,有且仅有一个唯一的终态。() 28.一个算符优先文法可能不存在算符优先函数与之对应。 ( ) 29.语法分析时必须先消除文法中的左递归 。 ()

30.LR分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。 () 31.逆波兰表示法表示表达式时无须使用括号。 () 32.静态数组的存储空间可以在编译时确定。 ()

33.进行代码优化时应着重考虑循环的代码优化,这对提高目标代码的效率将起更大作用。 () 34.两个正规集相等的必要条件是他们对应的正规式等价。 () 35.一个语义子程序描述了一个文法所对应的翻译工作。 () 36.设r和s分别是正规式,则有L(r|s)=L(r)L(s)。()

37.确定的自动机以及不确定的自动机都能正确地识别正规集。() 38.词法分析作为单独的一遍来处理较好。 ()

39.构造LR分析器的任务就是产生LR分析表。 () 40.规范归约和规范推导是互逆的两个过程。 ()

41.同心集的合并有可能产生新的“移进”/“归约”冲突。 () 42.LR分析技术无法适用二义文法。 ()

43.树形表示和四元式不便于优化,而三元式和间接三元式则便于优化。 ()

1

44.程序中的表达式语句在语义翻译时不需要回填技术。 () 45.对中间代码的优化依赖于具体的计算机。 ()

46.若一个句型中出现了某产生式的右部,则此右部一定是该句型的句柄。() 47.在程序中标识符的出现仅为使用性的。()

48.削减运算强度破坏了临时变量在一基本块内仅被定义一次的特性。() 49.编译程序与具体的机器有关,与具体的语言无关。()

××√×× √√××× √×√×× ××√√× √√√√× ××√×√ √√√√× ×√×√√ ×××√× ××××

二、选择题(请在前括号内选择最确切的一项作为答案划一个勾,多划按错论)

1. 一个编译程序中,不仅包含词法分析,( ),中间代码生成,代码优化,目标代码生成等五个部分。 A.语法分析 B.文法分析 C.语言分析 D.解释分析 2. 语法分析器则可以发现源程序中的( )。

A.语义错误 B.语法和语义错误 C.错误并校正 D.语法错误 3. 解释程序处理语言时 , 大多数采用的是( )方法。 A.源程序命令被逐个直接解释执行

B.先将源程序转化为中间代码 , 再解释执行 C.先将源程序解释转化为目标程序 , 再执行 D.以上方法都可以

4. 编译程序是一种( )。

A.汇编程序 B.翻译程序 C.解释程序 D.目标程序 5. 文法分为四种类型,即0型、1型、2型、3型。其中3型文法是( )。

A.短语文法 B.正则文法 C.上下文有关文法 D.上下文无关文法

6. 通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标代码生成等五个部分,还应包括( )。

A.模拟执行器 B.解释器 C.表格处理和出错处理 D.符号执行器 7. 一个句型中的最左( )称为该句型的句柄。

A.短语 B.简单短语 C.素短语 D.终结符号 8. 文法 G[E] : E→T∣E + T T→F∣T ﹡ F F→a∣ ( E )

该文法句型 E + F ﹡ (E + T) 的简单短语是下列符号串中的( )。 ① ( E + T ) ②E + T ③F ④ F ﹡ (E + T)

A.① 和 ③ B.② 和 ③ C.③ 和 ④ D.③ 9. 词法分析器用于识别( 。

A.句子 B.句型 C.单词 D.产生式 10. 在自底向上的语法分析方法中,分析的关键是( )。

A.寻找句柄 B.寻找句型 C.消除递归 D.选择候选式 11. 文法 G 产生的( )的全体是该文法描述的语言。

A.句型 B.终结符集 C.非终结符集 D.句子 12. 若文法 G 定义的语言是无限集,则文法必然是( )。 A.递归的 B.前后文无关的 C.二义性的 D.无二义性的

2

13. 四种形式语言文法中,1型文法又称为( )文法。

A.短语结构文法 B.前后文无关文法 C.前后文有关文法 D.正规文法 14. 一个文法所描述的语言是()。 A.唯一的 B.不唯一的 C.可能唯一,好可能不唯一 D.都不对 15. ( )和代码优化部分不是每个编译程序都必需的。 A.语法分析 B.中间代码生成 C.词法分析 D.目标代码生成 16.( )是两类程序语言处理程序。 A.高级语言程序和低级语言程序 B.解释程序和编译程序 C.编译程序和操作系统 D.系统程序和应用程序 17. 数组的内情向量中肯定不含有数组的( )的信息。

A.维数 B.类型 C.维上下界 D.各维的界差

18. 一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号,一个开始符号,以及一组( )。

A.句子 B.句型 C.单词 D.产生式

19. 文法分为四种类型,即0型、1型、2型、3型。其中2型文法是()。

A.短语文法 B.正则文法 C.上下文有关文法 D.上下文无关文法 20.文法 G 所描述的语言是( )的集合。

A.文法 G 的字母表 V 中所有符号组成的符号串 B.文法 G 的字母表 V 的闭包 V* 中的所有符号串 C.由文法的开始符号推出的所有终极符串 D.由文法的开始符号推出的所有符号串 21.词法分析器用于识别( )。 A.字符串 B.语句 C.单词 D.标识符

22.文法分为四种类型,即0型、1型、2型、3型。其中0型文法是()。

A.短语文法 B.正则文法 C.上下文有关文法 D.上下文无关文法 24.( )是一种典型的解释型语言。

A.BASIC B.C C.FORTRAN D.PASCAL 25.与编译系统相比,解释系统( )。

A.比较简单 , 可移植性好 , 执行速度快 B.比较复杂 , 可移植性好 , 执行速度快 C.比较简单 , 可移植性差 , 执行速度慢 D.比较简单 , 可移植性好 , 执行速度慢 26.用高级语言编写的程序经编译后产生的程序叫( )。

A.源程序 B.目标程序 C.连接程序 D.解释程序 27.词法分析器用于识别()。

A.字符串 B.语句 C.单词 D.标识符

28.编写一个计算机高级语言的源程序后 , 到正式上机运行之前,一般要经过( )这几步: (1) 编辑 (2) 编译 (3) 连接 (4) 运行

A.(1)(2)(3)(4) B.(1)(2)(3) C.(1)(3) D.(1)(4)

29.把汇编语言程序翻译成机器可执行的目标程序的工作是由( )完成的。 A.编译器 B.汇编器 C.解释器 D.预处理器 31.词法分析器的输出结果是( )。

A.单词的种别编码 B.单词在符号表中的位置 C.单词的种别编码和自身值 D.单词自身值 32. 正规式 M 1 和 M 2 等价是指( )。 A.M1和M2的状态数相等 B.M1和M2的有向边条数相等 C.M1和M2所识别的语言集相等 D.M1和M2状态数和有向边条数相等 33. 文法G:S→xSx|y所识别的语言是( )。

A.xyx B.(xyx)* C.xyx(n?0) D.x*yx*

34.如果文法G是无二义的,则它的任何句子α ( )。

A.最左推导和最右推导对应的语法树必定相同 B.最左推导和最右推导对应的语法树可能不同 C.最左推导和最右推导必定相同 D.可能存在两个不同的最左推导,但它们对应的语法树相同

3

nn