1、将编译程序分成若干个“遍”是为了 。
a.提高程序的执行效率
b.使程序的结构更加清晰
c.利用有限的机器内存并提高机器的执行效率
d.利用有限的机器内存但降低了机器的执行效率
2、构造编译程序应掌握 。
a.源程序 b.目标语言
c.编译方法 d.以上三项都是
3、编译程序绝大多数时间花在 上。
a.出错处理 b.词法分析
c.目标代码生成 d.管理表格
4、词法分析器的输入是 。
a.单词符号串 b.源程序
c.语法单位 d.目标程序
5、中间代码生成时所遵循的是- 。
a.语法规则 b.词法规则
c.语义规则 d.等价变换规则
6、编译程序是对 。
a.汇编程序的翻译 b.高级语言程序的解释执行
c.机器语言的执行 d.高级语言的翻译
7、语法分析应遵循 。
a.语义规则 b.语法规则
c.构词规则 d.等价变换规则
二、多项选择题
1、编译程序各阶段的工作都涉及到 。
a.语法分析 b.表格管理 c.出错处理
d.语义分析 e.词法分析
2、编译程序工作时,通常有 阶段。
a.词法分析 b.语法分析 c.中间代码生成
d.语义检查 e.目标代码生成
三、填空题
1、解释程序和编译程序的区别在于 。
2、编译过程通常可分为5个阶段,分别是 、语法分析 、代码优化和目标代码生成。 3、编译程序工作过程中,第一段输入是 ,最后阶段的输出为 程序。
4、编译程序是指将 程序翻译成 程序的程序。
一、单项选择题
1、文法G:S→xSx|y所识别的语言是 。
a. xyx b. (xyx)* c. xnyxn(n≥0) d. x*yx*
2、文法G描述的语言L(G)是指 。
a. L(G)={α|Sα , α∈VT*} b. L(G)={α|Sα, α∈VT*}
c. L(G)={α|Sα,α∈(VT∪VN*)} d. L(G)={α|Sα, α∈(VT∪VN*)}
3、有限状态自动机能识别 。
a. 上下文无关文法 b. 上下文有关文法
c.正规文法 d. 短语文法
4、设G为算符优先文法,G的任意终结符对a、b有以下关系成立 。
a. 若f(a)>g(b),则a>b b.若f(a) 5、如果文法G是无二义的,则它的任何句子α 。 a. 最左推导和最右推导对应的语法树必定相同 b. 最左推导和最右推导对应的语法树可能不同 c. 最左推导和最右推导必定相同 d. 可能存在两个不同的最左推导,但它们对应的语法树相同 6、由文法的开始符经0步或多步推导产生的文法符号序列是 。 a. 短语 b.句柄 c. 句型 d. 句子 7、文法G:E→E+T|T T→T*P|P P→(E)|I 则句型P+T+i的句柄和最左素短语为 。 a.P+T和i b. P和P+T c. i和P+T+i d.P和T 8、设文法为:S→SA|A A→a|b 则对句子aba,下面 是规范推导。 a. SSASAAAAAaAAabAaba b. SSASAAAAAAAaAbaaba c. SSASAASAaSbaAbaaba d. SSASaSAaSbaAbaaba 9、文法G:S→b|∧(T) T→T,S|S 则FIRSTVT(T) 。 a. {b,∧,(} b. {b,∧,)} c.{b,∧,(,,} d.{b,∧,),,} 10、产生正规语言的文法为 。 a. 0型 b. 1型 c. 2型 d. 3型 11、采用自上而下分析,必须 。 a. 消除左递归 b. 消除右递归 c. 消除回溯 d. 提取公共左因子 12、在规范归约中,用 来刻画可归约串。 a. 直接短语 b. 句柄 c. 最左素短语 d. 素短语 13、有文法G:E→E*T|T T→T+i|i 句子1+2*8+6按该文法G归约,其值为 。 a. 23 B. 42 c. 30 d. 17 14、规范归约指 。 a. 最左推导的逆过程 b. 最右推导的逆过程 c. 规范推导 d. 最左归约的逆过程 二、多项选择题 1、下面哪些说法是错误的 。 a. 有向图是一个状态转换图 b. 状态转换图是一个有向图 c.有向图是一个DFA d.DFA可以用状态转换图表示 2、对无二义性文法来说,一棵语法树往往代表了 。 a. 多种推导过程 b. 多种最左推导过程 c.一种最左推导过程 d.仅一种推导过程 e.一种最左推导过程 3、如果文法G存在一个句子,满足下列条件 之一时,则称该文法是二义文法。 a. 该句子的最左推导与最右推导相同 b. 该句子有两个不同的最左推导 c. 该句子有两棵不同的最右推导 d. 该句子有两棵不同的语法树 e.该句子的语法树只有一个 4、有一文法G:S→AB A→aAb|ε B→cBd|ε 它不产生下面 集合。 a. {anbmcndm|n,m≥0} b. {anbncmdm|n,m>0} c. {anbmcmdn|n,m≥0} d. {anbncmdm|n,m≥0} e. {anbncndn|n≥0} 5、自下而上的语法分析中,应从 开始分析。 a. 句型 b. 句子 c. 以单词为单位的程序 d. 文法的开始符 e. 句柄 6、对正规文法描述的语言,以下 有能力描述它。 a.0型文法 b.1型文法 c.上下文无关文法 d.右线性文法 e.左线性文法 三、填空题 1、文法中的终结符和非终结符的交集是 。词法分析器交给语法分析器的文法符号一定是 ,它一定只出现在产生式的 部。 2、最左推导是指每次都对句型中的 非终结符进行扩展。 3、在语法分析中,最常见的两种方法一定是 分析法,另一是 分析法。 4、采用 语法分析时,必须消除文法的左递归。 5、 树代表推导过程, 树代表归约过程。 6、自下而上分析法采用 、归约、错误处理、 等四种操作。 7、Chomsky把文法分为 种类型,编译器构造中采用 和 文法,它们分别产生 和 语言,并分别用 和 自动机识别所产生的语言。 四、判断题 1、文法 S→aS|bR|ε描述的语言是(a|bc)* ( ) R→cS 2、在自下而上的语法分析中,语法树与分析树一定相同。 ( ) 3、二义文法不是上下文无关文法。 ( ) 4、语法分析时必须先消除文法中的左递归。 ( ) 5、规范归约和规范推导是互逆的两个过程。 ( ) 6、一个文法所有句型的集合形成该文法所能接受的语言。 ( ) 五、综合题 1、有文法G:S→aAcB|Bd A→AaB|c B→bScA|b (1)试求句型aAaBcbbdcc和aAcbBdcc的句柄; (2)写出句子acabcbbdcc的最左推导过程。 2、对于文法G[S]: S→(L)|aS|a L→L, S|S 3、考虑文法G[T]: T→T*F|F F→F↑P|P P→(T)|i 证明T*P↑(T*F)是该文法的一个句型,并指出直接短语和句柄。 一、单项选择题 1、词法分析所依据的是 。 a. 语义规则 b. 构词规则 c. 语法规则 d. 等价变换规则 2、词法分析器的输出结果是 。 a. 单词的种别编码 b. 单词在符号表中的位置 c. 单词的种别编码和自身值 d. 单词自身值 3、正规式M1和M2等价是指 。 a. M1和M2的状态数相等 b. M1和M2的有向弧条数相等 c. M1和M2所识别的语言集相等 d. M1和M2状态数和有向弧条数相等 4、状态转换图(见图3-6-1)接受的字集为 。 a. 以 0开头的二进制数组成的集合 b. 以0结尾的二进制数组成的集合 c. 含奇数个0的二进制数组成的集合 d. 含偶数个0的二进制数组成的集合 5、词法分析器作为的阶段使整个编译程序结构更加简洁、明确,因此, 。 a. 词法分析器应作为的一遍 b. 词法分析器作为子程序较好 c. 词法分析器分解为多个过程,由语法分析器选择使用 d. 词法分析器并不作为一个的阶段 二、多项选择题 1、在词法分析中,能识别出 。 a. 基本字 b. 四元式 c. 运算符 d. 逆波兰式 e. 常数 2、令∑={a,b},则∑上所有以b开头,后跟若干个ab的字的全体对应的正规式为 。 a. b(ab)* b. b(ab)+ c.(ba)*b d. (ba)+b e. b(a|b) 三、填空题 1、确定有限自动机DFA是 的一个特例。 2、若二个正规式所表示的 相同,则认为二者是等价的。 3、一个字集是正规的,当且仅当它可由 所 。 四、判断题 1、一个有限状态自动机中,有且仅有一个唯一终态。 ( ) 2、设r和s分别是正规式,则有L(r|s)=L(r)|L(s)。 ( ) 3、自动机M和M′的状态数不同,则二者必不等价。 ( ) 4、确定的自动机以及不确定的自动机都能正确地识别正规集。 ( ) 5、对任意一个右线性文法G,都存在一个NFA M,满足L(G)=L(M)。 ( ) 6、对任意一个右线性文法G,都存在一个DFA M,满足L(G)=L(M)。 ( ) 7、对任何正规表达式e,都存在一个NFA M,满足L(G)=L(e)。 ( ) 8、对任何正规表达式e,都存在一个DFA M,满足L(G)=L(e)。 ( ) 五、基本题 1、设M=({x,y}, {a,b}, f,x,{y})为一非确定的有限自动机,其中f定义如下: f(x,a)={x,y} f(x,b)={y} f(y,a)=φ f(y,b)={x,y} 试构造相应的确定有限自动机M′。 即得到M′=({0,1,2}, {a,b}, f,0, {1,2}),其状态转换图如图3-6-5所示。 2、对给定正规式b*(d|ad)(b|ab)+,构造其NFA M; 1、 构造下面文法的LL(1)分析表。 D→ TL T→ int | real L→ id R R→ , id R | ε 2、 下面文法G[S]是否为LL(1)文法?说明理由。 S → A B | P Q x A → x y B → b c P → d P | ε Q → a Q | ε 3、 设有以下文法: G[S]:S→aAbDe|d A→BSD|e B→SAc| cD| ε D→Se| ε (1)求出该文法的每一个非终结符U的FOLLOW集。 (2)该文法是LL(1)文法吗? (3)构造C[S]的LL(1)分析表。 4、 将文法G[V]改造成为LL(1)的。 G[V]:V→N|N[E] E→V|V+E N→i 5、已知文法: G[A]: A→aAa|ε (1)该文法是LL(1)文法吗?为什么? (2)若采用LL(1)方法进行语法分析,如何得到该文法的LL(1)分析表? (3)若输入符号串“aaaa”,请给出语法分析过程。 第七节 习题 1、设有文法G[S]为: S→a|b|(A) A→SdA|S (1)完成算符优先关系表,并判断G[S]是否为算符优先文法。 (2)给出句型(SdSdS)的短语、简单短语、句柄、素短语和最左素短语。 (3)给出输入串(adb)#的分析过程。 第四节 习题 一、单项选择题 1、若a为终结符,则A→α·aβ为 项目 a.归约 b.移进 c.接受 d.待约 2、若项目集Ik含有A→α·,则在状态k时,仅当面临的输入符号a∈FOLLOW(A)时,才采取“A→α·”动作的一定是 。 a.LALR文法 b.LR(0)文法 c.LR(1)文法 d.SLR(1)文法 3、就文法的描述能力来说,有 。 a. SLR(1)⊂LR(0) b. LR(1)⊂LR(0)c. SLR(1)⊂LR(1)d.无二义文法⊂LR(1) 4、在LR(0)的ACTION子表中,如果某一行中存在标记“rj”的栏,则 。 a.该行必定填满rj b.该行未填满rj c.其他行也有rj d.goto子表中也有rj 5、一个 指明了在分析过程中的某时刻所能看到产生式多大一部分。 二、多项选择题 1、一个LR分析器包括 。 a.一个总控程序 b.一个项目集 c.一个活前缀 d.一张分析表 e.一个分析栈 2、LR分析器核心部分是一张分析表,该表包括 等子表。 a.LL(1)分析 b.优先关系 c.GOTO d.LR e.ACTION 3、每一项ACTION[S,a]所规定的动作包括 。 a.移进 b.比较 c.接受 d.归约 e.报错 4、对LR分析表的构造,有可能存在 动作冲突。 a.移进 b.归约 c.移进/归约 d.移进/移进 e.归约/归约 5、就文法的描述能力来说,有 。 a. SLR(1)⊂LR(1) b. LR(1)⊂SLR(1) c. LR(0)⊂LR(1) d. LR(1)⊂无二义文法 e. SLR(1)⊂无二义文法 6、对LR分析器来说,存在 等分析表的构造方法。 a.LALR b.LR(0) c.SLR(1) d.SLR(0) e.LR(1) 7、自上而下的语法分析方法有 。 a.算符优先分析法 b.LL(1)分析法 c.SLR(1)分析法 三、填空题 1、对于一个文法,如果能够构造 。使得它的 均是唯一确定的,则称该文法为LR文法。 2、字的前缀是指该字的 。 3、活前缀是指 的一个前缀,这种前缀不含 之后的任何符号。 4、在LR分析过程中,只要 的已扫描部分保持可归约成一个 ,则扫描过的部分正确。 5、将识别 的NFA确定化,使其成为以 为状态的DFA,这个DFA就是建立 的基础。 6、A→α·称为 项目;对文法开始符S′→α·为 项目;若a为终结符,则称A→α·aβ为 项目;若B为非终结符,则称A→α·aβ为 项目。 四、综合题 1、设文法G[S]为: S→rD D→D,i | i (1)构造识别文法活前缀的DFA(3分)。 (2)该文法是LR(0)文法吗(1分)?请说明理由(2分)。 (3)该文法是SLR(1)文法吗?若是,构造它的SLR(1)分析表(4分)。 第八节 习题 一、单项选择题 1、中间代码生成所依据的是 。 a.语法规则 b.词法规则 c.语义规则 d.等价变换规则 2、四元式之间的联系是通过 实现的。 a.指示器 b.临时变量 c.符号表 d.程序变量 3、后缀式ab+cd+/可用表达式 来表示。 a.a+b/c+d b.(a+b)/(c+d) c.a+b/(c+d) d.a+b+c/d 4、表达式(┓A∨B)∧(C∨D)的逆波兰表示为 。 a. ┓AB∨∧CD∨ b. A┓B∨CD∨∧ c. AB∨┓CD∨∧ d. A┓B∨∧CD∨ 5、中间代码的树型表示所对应的表达式为 。 a.A+B+C+D b.A+(B+C)+D c.(A+B)+C+D d.(A+B)+(C+D) 6、四元式表示法的优点为 。 a.不便于优化处理,但便于表的更动 b.不便于优化处理,但节省存储空间 c.便于优化处理,也便于表的更动 d.便于表的更动,也节省存储空间 7、终结符具有 属性。 二、多顶选择题 1、中间代码主要有 。 a.四元式 b.二元式 c.三元式 d.后缀式 e.间接三元式 2、下面中间代码形式中,能正确表示算术表达式a+b+c的有 。 a.ab+c+ b.abc++ c. d. e.a+b+c 3、在下面的 语法制导翻译中,采用拉链-回填技术。 a.赋值语句 b.goto语句 c.条件语句 d.循环语句 4、下列 中间代码形式有益于优化处理。 a.三元式 b.四元式 c.间接三元式 d.逆波兰表示法 e.树形表示法 5、在编译程序中安排中间代码生成的目的是 。 a.便于进行存储空间的组织 b.利于目标代码的优化 c.利于编译程序的移植 d.利于目标代码的移植 e.利于提高目标代码的质量 6、下面的中间代码形式中, 能正确表示算术表达式a+b*c。题) a.ab+c* b.abc*+ c.a+b*c d. e. 7、三地址代码语句具体实现通常有 表示方法。 a.逆波兰表示 b.三元式 c.间接三元式 d.树形表示 e.四元式 三、填空题 1、中间代码有 等形式,生成中间代码主要是为了使 。 2、语法制导翻译既可以用来产生 代码,也可以用来产生 指令,甚至可用来对输入串进行 。 3、当源程序中的标号出现“先引用后定义”时,中间代码的转移地址须持 时才能确定,因而要进行 。 4、文法符号的属性有两种,一种称为 ,另一种称为 。 5、后缀式abc-/所代表的表达式是 ,表达式(a-b)*c可用后缀式 表示。 6、用一张 辅以 的办法来表示中间代码,这种表示法称为间接三元式。 四、综合题 1、给出下列表达式的逆波兰表示(后缀式): ① a*(-b+c) ② (A∨B)∧(C∨┑D∧E) 2、写出算术表达式:A+B*(C-D)+E/(C-D)↑N的 ①四元式序列;②三元式序列;③间接三元式序列 第三节 习题 一、单项选择题 1、编译程序使用 区别标识符的作用域。 a. 说明标识符的过程或函数名 b. 说明标识符的过程或函数的静态层次 c. 说明标识符的过程或函数的动态层次 d. 标识符的行号 2、在目标代码生成阶段,符号表用于 。 a. 目标代码生成 b. 语义检查 c. 语法检查 d. 地址分配 3、过程信息表不包含 。 a. 过程入口地址 b. 过程的静态层次 c. 过程名 d. 过程参数信息 4、下列关于标识符和名字叙述中,正确的是 。 a. 标识符有一定的含义 b. 名字是一个没有意义的字符序列 c. 名字有确切的属性 d. a~c都不正确 二、多项选择题 1、符号表的每一项均包含 。 a. 名字栏 b. 类型栏 c. 信息栏 d. 值栏 e. a~d均包含 2、对编译程序所用到的符号表,涉及的操作有 。 a. 填写或更新信息栏内容 b. 填入新名 c.给定名字,访问它的有关信息 d. 杂凑技术 e.线性表和排序二叉树 3、源程序中的错误一般有 。 a. 词法错误 b. 语法错误 c. 语义错误 d. 编译错误 e. 违反环境的错误 三、填空题 1、符号表中名字栏内容有两种填写方式,它们是 填写和 填写。 2、词法分析阶段的错误主要是 ,可通过 的办法纠正错误。 3、符号表中名字的有关信息在 和 过程中陆续填入。 4、在目标代码生成阶段,符号表是 的依据。 第五节 习题 一、单项选择题 1、优化可生成 的目标代码。 a.运行时间较短 b.占用存储空间较小 c.运行时间短但占用内存空间大 d.运行时间短且占用存储空间小 2、对一个基本块来说, 是正确的。 a.只有一个入口语句和一个出口语句 b.有一个入口语句和多个出口语句 c.有多个入口语句和一个出口语句 d.有多个入口语句和多个出口语句 二、多项选择题 1、根据优化所涉及的范围,可将优化分为 。 a.局部优化 b.过程优化 c.全局优化 d.循环优化 e.四元式优化 2、下列优化中,属于循环优化的有 。 a.强度削弱 b.合并已知量 c.删除无用赋值 d.删除归纳变量 e.代码外提 三、填空题 1、局部优化是 范围内进行的一种优化。 2、在一个基本块内,可实行3种优化方法,即合并已知量、 、 。 3、优化就是对程序进行各种 变换,使之能生成更有效的 。 4、在优化中,可把循环中的 提到循环外面去,这种方法称为 。 下载本文