五套编译原理期末考试试卷及答案

上传人:无*** 文档编号:136173245 上传时间:2022-08-16 格式:DOC 页数:39 大小:791KB
收藏 版权申诉 举报 下载
五套编译原理期末考试试卷及答案_第1页
第1页 / 共39页
五套编译原理期末考试试卷及答案_第2页
第2页 / 共39页
五套编译原理期末考试试卷及答案_第3页
第3页 / 共39页
资源描述:

《五套编译原理期末考试试卷及答案》由会员分享,可在线阅读,更多相关《五套编译原理期末考试试卷及答案(39页珍藏版)》请在装配图网上搜索。

1、得分一 填空题(每空 2 分,共 20 分)1. 不同的编译程序关于数据空间的存储分配策略可能不同,但大部分编译中采用的方案有两种:静态存储分配方案和动态存储分配方案,而后者又分为(1) 和 (2) 。2. 规范规约是最(3)规约。3. 编译程序的工作过程一般划分为 5 个阶段:词法分析、(4) 、语义分析与中间代码生成,代码优化及(5) 。另外还有(6)和出错处理。4表达式 x+y*z/(a+b)的后缀式为 (7) 。5文法符号的属性有综合属性和 (8)。6假设二位数组按行存放,而且每个元素占用一个存储单元,则数组 a1.15,1.20某个元素 ai,j的地址计算公式为(9)。7局部优化是局

2、限于一个(10)范围内的一种优化。得分二 选择题(1-6 为单选题,7-8 为多选题,每问 2 分,共 20 分)1. 一个上下文无关文法 G 包括四个组成部分:一组终结符,一组非终结符,一个( ),以及一组( )。A 字符串B 产生式C 开始符号D 文法2.程序的基本块是指( )。A 一个子程序B 一个仅有一个入口和一个出口的语句C 一个没有嵌套的程序段D 一组顺序执行的程序段,仅有一个入口和一个出口3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于( )分析方法。A 自左向右B 自顶向下C 自底向上D 自右向左4在通常的语法分析方法中,( )特别适用于表达式的分析。A 算符优先

3、分析法B LR 分析法C 递归下降分析法D LL(1)分析法5经过编译所得到的目标程序是( )。A 四元式序列B 间接三元式序列C 二元式序列D 机器语言程序或汇编语言程序6 一个文法所描述的语言是( );描述一个语言的文法是( )。A 唯一的B 不唯一的C 可能唯一,也可能不唯一7 如果在文法 G 中存在一个句子,当其满足下列条件( )之一时,则称该文法是二义文法。A 其最左推导和最右推导相同 B 该句子有两个不同的最左推导C 该句子有两个不同的最右推导 D 该句子有两棵不同的语法树E 该句子对应的语法树唯一8 下面( )语法制导翻译中,采用拉链回填技术。A. 赋值语句B. 布尔表达式的计算

4、C. 条件语句D. 循环语句三 解答题(共 60 分)得分1 (共 15 分)已知文法 GE:EETE|(E)|iT*|+(1) 将文法 G 改造成 LL(1)文法;(5 分)(2) 构造文法 G 中每个非终结符的 FIRST 集合及 FOLLOW 集合;(5 分)(3) 构造 LL(1)分析表。(5 分)2 (共 12 分)给定文法 GS:SS(S)|(1) 给出句子()()()()的规范推导过程;(4 分)(2) 指出每步推导所得句型的句柄;(4 分)(3) 画出该句子的语法推导树。(4 分)3 (共 8 分)在一个移入-规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即

5、执行括号中的动作。AaBprint “0”;Acprint “1”;BAbprint “2”;(1) 当分析器的输入为 aacbb 时,打印的字符串是什么?(3 分)(2) 写出分析过程。(5 分)4 (10 分)翻译循环语句 while (ad) then x:=y+z 。要求:给出加注释的分析树及四元式序列。参考以下部分翻译模式:(1) Sif E then M S1 backpatch(E.truelist,M.quad); S.nextlist:=merge(E.falselist,S1 .nextlist)(2) Swhile M1 E do M2 S1 backpatch(S1.n

6、extlist,M1,.quad);backpatch(E.truelist,M2,.quad);S.nextlist:=E.falselistemit (j,-,-,M1 .quad)(3)SAS.nextlist:=makelist()(4)LSL.nextlist:=S.nextlist(5)MM.quad:=nextquad(6)Eid1 relop id2E.truelist:=makelist(nextquad);e.falselist:=makelist(nextquad+1);emit(jrelop.op,id1.place ,id2.place,0);emit(j,-,-,0

7、)(7) SL:=Eemit(:=,E.place,-,L.place)(8) EE1+E2E.place:=newtemp;emit(+,E1.place,E2.place,E.place,)5 (共 15 分)设有表格构造文法 GS:Sa|(T)TT,S|S(1) 计算文法 GS的 FIRSTVT 集和 LASTVT 集。(5 分)(2) 构造 GS的优先关系表,并判断 GS是否为算符优先文法。(5 分)(3) 计算 GS的优先函数。(5 分)得分二单项选择题(每题 2 分,共 10 分)1. 设有文法 GI: II1|I0|Ia|Ic|a|b|c下列符号串中是该文法句子的有()。 ab0

8、 a0c01 aaa bc10可选项有:A BCD2.程序的基本块是指()。A 一个子程序B 一个仅有一个入口和一个出口的语句C 一个没有嵌套的程序段D 一组顺序执行的程序段,仅有一个入口和一个出口3. 高级语言编译程序常用的语法分析方法中,递归下降分析法属于()分析方法。A 自左向右B 自顶向下C 自底向上D 自右向左4经过编译所得到的目标程序是()。A 四元式序列B 间接三元式序列C 二元式序列D 机器语言程序或汇编语言程序5 运行阶段的存储组织与管理的目的是()。 提高编译程序的运行速度 节省编译程序的存储空间 提高目标程序的运行速度 为运行阶段的存储分配做准备可选项有:A. B. C.

9、 D. 2.(10 分) 已知文法 GS:得分SaBc|bABAaAb|bBb|(4) 构造其 LL(1)分析表;(5) 判断符号串 baabbb 是否为该文法的句子(写出含有符号栈、输入串和规则的分析过程)。3. (10 分) 已知文法 G 为:EE+T|TTT*P|PPi(1) 构造该文法的优先关系表(不考虑语句括号#),并指出此文法是否为算符优先文法。(2) 构造文法 G 的优先函数表。4 (8 分)在一个移入-规约分析过程中采用以下的语法制导翻译模式,在按一个产生式规约时,立即执行括号中的动作。SbAbprint “1”A(Bprint “2”Aaprint “3”BAa)print

10、“4”(3) 当输入序列为 b(aa)a)a)b 时,打印的字符串是什么?(4) 写出移入-规约分析过程。5 (12 分)翻译循环语句 while (xy) do if (a=b) then x:=2*y+a 。要求:给出加注释的分析树、三地址码序列及相应的四元式序列。参考以下部分翻译模式:(1) Sif E then M S1 backpatch(E.truelist,M.quad); S.nextlist:=merge(E.falselist,S1 .nextlist)(2) Swhile M1 E do M2 S1 backpatch(S1.nextlist,M1,.quad);back

11、patch(E.truelist,M2,.quad);S.nextlist:=E.falselistemit (j,-,-,M1 .quad)(3)SAS.nextlist:=makelist()(4)LSL.nextlist:=S.nextlist(5)MM.quad:=nextquad(6)Eid1 relop id2E.truelist:=makelist(nextquad);e.falselist:=makelist(nextquad+1);emit(jrelop.op,id1.place ,id2.place,0);emit(j,-,-,0)(7) SL:=Eemit(:=,E.pl

12、ace,-,L.place)(8) EE1+E2E.place:=newtemp;emit(+,E1.place,E2.place,E.place,)6. (8 分) Generate assembly code for the following sequence assuming that x,y and z are in memory locations(noticing only two registers R1 and R2).S=0I=0L1: if xy goto L2Z=s+aiI=i+1 Goto L1L2:7 (6 分) Give out the all basic blo

13、cks of the following program fragment and construct the relevant flow graph(DAG).read C A=0 B=1L4: A=A+Bif BC goto L2 B=B+1goto L4 L2: write A8. (8 分)Translate the assignment statement bi=b*c-b*d into(1) A syntax tree.(2) Three address instructions.答案:(1) 栈式动态存储分配(2) 堆式动态存储分配(3) 左(4) 语法分析(5) 目标代码生成(

14、6) 表格管理(7) xyz*ab+/+(8) 继承属性(9) a+(i-1)*20+j-1(10) 基本块一、选择题(每问 2 分,共 20 分)1.C B2.D3.B4.A5.D6.A,C7.BCD,选对一个得 1 分且不超过满分,选错一个扣一分,扣完为止。8.BCD,选对一个得 1 分且不超过满分,选错一个扣一分,扣完为止。二、解答题1(1)文法存在左递归,消除左递归后的文法为:E(E)E|i E(2 分)ETEE| (2 分)T*|+(1 分)(2)(5 分)没考虑#扣 0.5 分,其它错或少写一个扣 0.5 分FIRST(E)=(,iFIRST(E)=*,+, FIRST(T)=*,

15、+FOLLOW(E)=),*,+,#FOWLLOW(E)= ),*,+,# FOLLOW(T)=(,i(3)每错一个扣 0.5 分,全错或不写不得分,扣完为止,共 5 分()i*+#EE(E)EEiEEE ETEEETEEE E E TT*T+2(1)规范推导过程如下。写错推导符号扣 0.5 分,错写或少写一步推导扣 0.5 分,扣完为止,最左推导扣 2 分,共 4 分。S S(S) S(e ) S(S)() S(e )() S(S)()() S(S(S)()() S(S(e )()() S(S(S)()()() S(S(e )()()() S(e )()()() e ()()()()(2)(

16、1)中加下划线的部分是句柄,标识如(1)。每少写一个句柄扣 0.5 分,扣完为止,共 4 分。(3)每少写步扣 0.5 分,扣完为止,共 4 分。SS( S )S( S )S( S ) S( S )S( S ) 3(1)打印的字符串是:12020(错一个扣 0.5 分,共 3 分)(2)归约过程中错一步扣 0.5 分,扣完为止。(共 5 分)4(1)每少写一步扣 0.5 分,扣完为止,共 5 分。Swhile M1.q=100E1.t=102do M2.q=102S1E1.f=107adxE5.p=y+ E6.p=z(2)少写一个四元式扣 0.5 分,全错或不写不yz四元式序列为:100( j

17、 , c, d ,104) 103( j, _, _,106) 104(+, y, z,T1) 105(:=,T1, _, x) 106( j, _, _,100)5(1)少写一个扣 1 分,全错或不写不得分,共 5 分。FIRSTVT(S)=a,( FIRSTVT(T)=, a,( LASTVT(S)= a,) LASTVT(T)= a,), ,(2)优先表如下。每错一个扣 0.5 分,全错或不写不得分,扣完为止,共 3 分文法 GS没有两个非终结符相邻的情况,且其优先表中任一对终结符之间最多满足、 三种关系中的一种,因此是 GS算符优先文法。(2 分)可以不考虑终结符“#”。a(),#A(

18、),#或者(3)优先函数。可以不考虑终结符“#”。每错一个扣 0.5 分,全错或不写不得分,扣完为止,共 5 分。a(),#f662662g777252或者a(),f44244g55523三、 填空题(每空 2 分,共 20 分)1 目标程序 (target code)语法分析(syntax analyzer)代码优化器(codeoptimizer)代码产生器(code generator)符号表管理(symbol tablemanager)2继承属性(inherited attribute)3局部优化(local optimization)4 四元式(quatriple)5 E+ * ( )

19、 id四、单项选择题(每题 2 分,共 10 分)1.B2.D3.B4.D5.C五、解答题(共 70 分)1(1) L(G)=0m1m|M1 共 2 分,写成扣 1 分(2) S=0S1=00S11=000111,共 3 分, =写成-扣 1 分(3) 共 3 分,错处扣 0.5 分,扣完为止2.(1)空白表格也可以填写“错误”字样,共 4 分,错一个扣 0.5 分,扣完为止abc$(#)SSaBcSbABAAaAbAbBBbBB(2)共 6 分,其中判断“baabbb 是该文法句子”为 2 分,其他错一个扣 0.5 分,扣完为止符号栈输入串规则$Sbaabbb$BAbbaabbb$SbAB$

20、BAaabbb$BbAaaabbb$AaAb$BbAabbb$BbbAaabbb$AaAb$BbbAbbb$Bbbbbbb$Ab$Bbbbb$Bbb$b$B$success3.(1) 共 6 分,其中判断“该文法为算符优先文法”为 2 分,其他错一个扣 0.5 分,扣完为止+*i+(2) 共 4 分,错一个扣 0.5 分,扣完为止+*if244g1354(1)34242421,共 4 分,错一个扣 0.5 分(2)共 4 分,错一个扣 0.5 分,扣完为止stackInput stringaction$b(aa)a)a)b$b(aa)a)a)b$shift$b(aa)a)a)b$abbb$sh

21、ift$b(aa)a)a)b$bbb$shift$b(aa)a)a)b$bb$shift$b(aa)a)a)b$shift$b(Aa)a)a)b$reduce, Aa$b(Aa)a)a)b$shift$ b(Aa)a)a)b$shift$ b(Ba)a)b$reduce, BAa)$b(Aa)a)b$reduce, A(B$b(Aa)a)b$shift$b(Aa)a)b$shift$b(Ba)b$reduce, BAa)$b(Aa)b$reduce, A(B$b(Aa)b$shift$b(Aa)b$shift$b(Bb$reduce, BAa)$bAb$reduce, A(B$bAb$shif

22、t$S$reduce, SbAb$s$accept5 共 12 分,其中带注释的分析树、三地址码序列和四元式序列分别为 4 分,错一个序列扣 0.5 分,而错某点(某项)少于或等于 5 个扣 0.5 分带注释语法树(略)三地址码序列四元式序列M1: if (xy) goto M2100(j, x,y,102)goto M4101(j,-,-,108)M2: if (a=b) goto M3102(j=,a,b,104)goto M1103(j,-,-,100)M3: t1=2*y104(*,2,y,t1)t2=t1+a105(+,t1,a,t2)x=t2106(=,t2,-,x)goto M1

23、107(j,-,-,100)M4:108(-,-,-,-)6共 8 分,错一个扣 0.5 分,扣完为止LD R1,0ST S,R1ST I,R1 L1: LD R1,XSUB R1,R1,Y (OR SUB R1,Y) BGTZ R1,L2LD R2,a(R1)ADD R2,R2,S (OR ADD R2,S) ST Z,R2LD R1,I (从这开始,下面的语句中的 R1 也可以全部变成 R2) ADD R1,R1,1 (OR INC R1)ST I,R1BR L1L2:7 共 6 分,基本块划分和流图各为 3 分,错一处扣 1 分,扣完为止read c B1 A=0B=1B2L4: A=A

24、+BIf BC goto L2 (OR B4)B3B=B+1GotoL4 (OR B2)B4L2: write A8. (1)共 4 分,错一项扣 1 分,扣完为止(2)共 4 分,错一项扣 1 分,扣完为止 t1=b*ct2=b*d t3=t1-t2t4=i+1 (or t4=i) bt4=t3一、判断题:1.一个上下文无关文法的开始符,可以是终结符或非终结符。()2.一个句型的直接短语是唯一的。()3.已经证明文法的二义性是可判定的。()4.每个基本块可用一个 DAG 表示。()5.每个过程的活动记录的体积在编译时可静态确定。()6.2 型文法一定是 3 型文法。()7.一个句型一定句子。

25、()8.算符优先分析法每次都是对句柄进行归约。()9.采用三元式实现三地址代码时,不利于对中间代码进行优化。()10.编译过程中,语法分析器的任务是分析单词是怎样构成的。()11.一个优先表一定存在相应的优先函数。()12.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。()13.递归下降分析法是一种自下而上分析法。()14.并不是每个文法都能改写成 LL(1)文法。()15.每个基本块只有一个入口和一个出口。()16.一个 LL(1)文法一定是无二义的。()17.逆波兰法表示的表达试亦称前缀式。()18.目标代码生成时,应考虑如何充分利用计算机的寄存器的问题。()19.正规文法产生的

26、语言都可以用上下文无关文法来描述。()20.一个优先表一定存在相应的优先函数。()21.3 型文法一定是 2 型文法。()22.如果一个文法存在某个句子对应两棵不同的语法树,则文法是二义性的。()二、填空题:1.( )称为规范推导。2.编译过程可分为 () ,(),(),()和()五个阶段。3.如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是()。4.从功能上说,程序语言的语句大体可分为()语句和()语句两大类。5.语法分析器的输入是(),其输出是()。6.扫描器的任务是从()中识别出一个个()。7.符号表中的信息栏中登记了每个名字的有关的性质,如()等等。8.一个过程相应的 DI

27、SPLAY 表的内容为()。9.一个句型的最左直接短语称为句型的()。10.常用的两种动态存贮分配办法是()动态分配和()动态分配。11.一个名字的属性包括()和()。12.常用的参数传递方式有(),()和()。13.根据优化所涉及的程序范围,可将优化分成为(),()和()三个级别。14.语法分析的方法大致可分为两类,一类是()分析法,另一类是()分析法。15.预测分析程序是使用一张()和一个()进行联合控制的。16.常用的参数传递方式有(),()和()。17.一张转换图只包含有限个状态,其中有一个被认为是()态;而且实际上至少要有一个()态。18.根据优化所涉及的程序范围,可将优化分成为()

28、,()和()三个级别。19.语法分析是依据语言的()规则进行。中间代码产生是依据语言的()规则进行的。20.一个句型的最左直接短语称为句型的()。21.一个文法 G,若它的预测分析表 M 不含多重定义,则该文法是()文法。22.对于数据空间的存贮分配, FORTRAN 采用()策略, PASCAL 采用()策略。23.如果一个文法存在某个句子对应两棵不同的语法树, 则称这个文法是()。24.最右推导亦称为(),由此得到的句型称为()句型。25.语法分析的方法大致可分为两类,一类是()分析法,另一类是()分析法。26.对于文法 G,仅含终结符号的句型称为 ()。27.所谓自上而下分析法是指()。

29、28.语法分析器的输入是(),其输出是()。29.局限于基本块范围的优化称()。30.预测分析程序是使用一张()和一个()进行联合控制的。31.2 型文法又称为()文法;3 型文法又称为()文法。32.每条指令的执行代价定义为()。33.算符优先分析法每次都是对()进行归约。三、名词解释题:1.局部优化2.二义性文法3.DISPLAY 表4.词法分析器5.最左推导6.语法7.文法8.基本块9.语法制导翻译10.短语11.待用信息12.规范句型13.扫描器14.超前搜索15.句柄16.语法制导翻译17.规范句型18.素短语19.语法20.待用信息21.语义四、简答题:1.写一个文法 G, 使其语

30、言为 不以 0 开头的偶数集。2.已知文法 G(S)及相应翻译方案SaAbprint “1”Saprint “2”AASprint “3”Acprint “4”输入 acab, 输出是什么?3. 已知文法 G(S) SbAaA(B | a BAa)写出句子 b(aa)b 的规范归约过程。4. 考虑下面的程序:procedure p(x, y, z); beginy:=x+y;z:=z*z; end beginA:=2;B:=A*2; P(A, A, B); Print A, Bend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 A, B 的值是什么? 5.文法 G(S)SdA

31、BAaA| aBBb| 描述的语言是什么?6.证明文法 G(S)SSaS| 是二义性的。7.已知文法 G(S)SBA ABS| d BaA| bS | c的预测分析表如下abcd#SSBASBASBAAABSABSABSAdBBaABbSBc给出句子 adccd 的分析过程。8.写一个文法 G, 使其语言为 L(G)=albmclanbn| l=0, m=1, n=2 9.已知文法 G(S):Sa| (T)TT,S|S的优先关系表如下:关系a(),a-.(.=.,.请计算出该优先关系表所对应的优先函数表。10.何谓优化?按所涉及的程序范围可分为哪几级优化?11.目标代码有哪几种形式?生成目标代

32、码时通常应考虑哪几个问题?12.一字母表=a, b,试写出上所有以 a 为首的字组成的正规集相对应的正规式。13.基本的优化方法有哪几种?14.写一个文法 G, 使其语言为 L(G)=abncn| n0 15.考虑下面的程序:procedure p(x, y, z); beginy:=y+z;z:=y*z+xend; begina:=2;b:=3;p(a+b, b, a); print aend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a 的值是什么? 16.写出表达式 ab*(c-d)/e 的逆波兰式和三元序列。17.证明文法 G(A)AAA | (A)| 是二义性的。

33、18.令=a,b,则正规式 a*b|b*a 表示的正规集是什么?19.何谓 DISPLAY 表?其作用是什么?20.考虑下面的程序:procedure p(x, y, z); beginy:=y+2;z:=z+x; end begina:=5;b:=2;p(a+b, a-b, a); print aend.试问,若参数传递的方式分别采用传地址和传值时,程序执行后输出 a 的值是什么? 21.写一个文法 G, 使其语言为 L(G)=anbncm| n0 为奇数, m0 为偶数 22.写出表达式 a:=(b+c)*e+(b+c)/f 的逆波兰式和三元序列。23.一个文法 G 别是 LL(1)文法的

34、充要条件是什么?24.已知文法 GS SS*aF | aF | *aF F+aF | +a消除文法左递归和提公共左因子。25.符号表的作用是什么?符号表查找和整理技术有哪几种?五、计算题:1.设文法 G(S): S | a | (T) TT,S | S 消除左递归; 构造相应的 FIRST 和 FOLLOW 集合; 构造预测分析表2.语句 if E then S(1) 改写文法,使之适合语法制导翻译;(2) 写出改写后产生式的语义动作。3.设文法 G(S):S(T) | a TT+S | S(1)计算 FIRSTVT 和 LASTVT;(2)构造优先关系表。4.设某语言的 for 语句的形式为

35、for i:E(1) to E(2) do S其语义解释为i:E(1) LIMIT:E(2)again: if iLIMIT then BeginS;i:i1 goto again End;(1)写出适合语法制导翻译的产生式;(2)写出每个产生式对应的语义动作。5.把语句while a0 then a:=a+1 else a:=a*3-1;翻译成四元式序列。6.设有基本块D:=A-CE:=A*CF:=D*ES:=2T:=A-CQ:=A*CG:=2*SJ:=T*QK:=G*5L:=K+JM:=L假设基本块出口时只有 M 还被引用,请写出优化后的四元序列。7.已知文法 G(S)Sa | | (T)

36、 TT,S | S(1) 给出句子(a,(a,a)的最左推导;(2) 给出句型(T,S),a)的短语, 直接短语,句柄。8.对于 C 语言 do S while E 语句(1)改写文法,使之适合语法制导翻译;(2)写出改写后产生式的语义动作。9.已知文法 G(S) SaAcBe AAb| b Bd(1)给出句子 abbcde 的最左推导及画出语法树;(2)给出句型 aAbcde 的短语、素短语。10.设文法 G(S): S(T) | aS | a TT,S | S消除左递归和提公共左因子;构造相应的 FIRST 和 FOLLOW 集合;构造预测分析表。11.把语句 if X0 Y0 do X:

37、=A*3 else Y:=B+3;翻译成四元式序列。12.已知文法 G(S)EE+T | TTT*F| F F(E)| i(1) 给出句型 (i+i)*i+i 的最左推导及画出语法树;(2) 给出句型 (E+T)*i+F 的短语,素短语和最左素短语。13.设文法 G(S):ST | ST TU |TU Ui |-U(1)计算 FIRSTVT 和 LASTVT;(2)构造优先关系表。参考答案一、是非题:1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.二、填空题:1.(最右推导)2.(词法分析),(语法分析),(中间代码生成),(代

38、码优化),(目标代码生成)3.(二义性的)4.(执行性),(说明性)5.(单词符号),(语法单位)。6.(源程序),(单词符号)7.(类型、种属、所占单元大小、地址)8.(现行活动记录地址和所有外层最新活动记录的地址) 9.(句柄)10.(栈式),(堆式)11.(类型),(作用域)12.(传地址),(传值),(传名)13.(局部优化),(循环优化),(全局优化)14.(自上而下),(自下而上)15.(分析表),(符号栈)16.(传地址),(传值),(传名)17.(初),(终)18.(局部优化),(循环优化),(全局优化)19.(语法),(语义)20.(句柄) 21.(LL(1) 文法)22.(

39、静态),(动态)23.(二义性文法)24.(规范推导),(规范)25.(自上而下),(自下而上)26.(句子)27.(从开始符号出发,向下推导,推出句子)28.(单词符号),(语法单位)29.(局部优化)30.(分析表),(符号栈)31.(上下文无关文法),(正规)32.(指令访问主存次数加 1)33.(最左素短语)三、名词解释题:1.局部优化-局限于基本块范围的优化称。2.二义性文法-如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义性文法。 3.DISPLAY 表-过程的嵌套层次显示表,记录该过程的各外层过程的最新活动记录的起始地址。4.词法分析器-执行词法分析的程序。5.最

40、左推导-任何一步=都是对中的最右非终结符替换。6.语法-一组规则,用它可形成和产生一组合式的程序。7.文法-描述语言的语法结构的形式规则。8.基本块-指程序中一顺序执行的语句序列,其中只有一个入口和一个出口,入口就是其中的第一个语句,出口就是其中的最后一个语句。9.语法制导翻译-在语法分析过程中,根据每个产生式所对应的语义子程序进行翻译的办法叫做语法制导翻译。10.短语-令 G 是一个文法,S 划文法的开始符号,假定是文法 G 的一个句型,如果有 SA且A,则称是句型相对非终结符 A 的短语。第 1 页 共 25 页11.待用信息-如果在一个基本块中,四元式 i 对 A 定值,四元式 j 要引

41、用 A 值,而从 i 到 j 之间没有 A 的其它定值,则称 j 是四元式 i 的变量 A 的待用信息。12.规范句型-由规范推导所得到的句型。13.扫描器-执行词法分析的程序。14.超前搜索-在词法分析过程中,有时为了确定词性,需超前扫描若干个字符。15.句柄-一个句型的最左直接短语。16.语法制导翻译-在语法分析过程中,根据每个产生式所对应的语义程序进行翻译的方法叫做语法制导翻译。17.规范句型-由规范推导所得到的句型。18.素短语-素短语是指这样一个短语,至少含有一个终结符,并且,除它自身外不再含任何更小的素短语。19.语法-是组规则,用它可形成和产生一个合式的程序。20.待用信息-如果

42、在一个基本块中,四元式 i 对 A 定值,四元式 j 要引用 A 值,而从 i 到 j 之间没有 A 的其它定值,则称 j 是四元式 i 的变量 A 的待用信息。21.语义-定义程序的意义的一组规则。四、简答题:1.所求文法是 GS: SAB |B A0 AAD |C B2 |4 |6 |8C1 |3 |5 |7 |9 |B D0 |C2.输出是 42313.句子 b(aa)b 的规范归约过程:步骤符号栈输入串动作0#b(aa)b#预备1#b(aa)b#移进2#b(aa)b#移进3#b(aa)b#移进4#b(Aa)b#归约5#b(Ma)b#移进6#b(Ma)b#移进7#b(Bb#归约8#bAb

43、#归约9#bAb#移进10#S#接受4.传地址 A=6,B=16传值 A=2,B=45.L(G)=danbm |n0, m0 6.证明:因为文法 GS存在句子 aa 有两个不同的最左推导,所以文法 GS是是二义性的。S=SaS=SaSaS=aSaS=aaS=aaS=SaS=aS=aSaS=aaS=aa7.句子 adccd 的分析过程:步骤符号栈输入串产生式0#Sadccd#1#ABadccd#SBA2#AAaadccd#BaA3#AAdccd#第 2 页 共 25 页4#Addccd#Ad5#Accd#6#SBccd#ABS7#Scccd#Bc8#Scd#9#ABcd#Bc10#Acd#11#Ad#12#dd#Ad13#

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!