欢迎来到得力文库 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
得力文库 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    编译知识学习原理小题'答案库.doc

    • 资源ID:810642       资源大小:143.02KB        全文页数:12页
    • 资源格式: DOC        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    编译知识学习原理小题'答案库.doc

    ''编译原理编译原理常见题型常见题型一、填空题一、填空题1.编译程序的工作过程一般可以划分为 词法分析 , 语法分析 , 中间代码 生成 , 代码优化 (可省) , 目标代码生成 等几个基本阶段。2.若源程序是用高级语言编写的,目标程序是 机器语言程序或汇编程序 ,则其翻译程 序称为编译程序.3.编译方式与解释方式的根本区别在于 是否生成目标代码 . 5.对编译程序而言,输入数据是 源程序 ,输出结果是 目标程序 . 7.若源程序是用高级语言编写的,目标程序是机器语言程序或汇编程序 ,则其翻译程序称 为 编译程序 。8.一个典型的编译程序中,不仅包括词法分析、语法分析、中间代码生成、代码优化、目 标代码生成等五个部分,还应包括 表格处理 和 出错处理 。其中,词法分析器用于 识别 单词 。10.一个上下文无关文法所含四个组成部分是 一组终结符号 、 一组非终结符号 、 一个开始符号 、 一组产生式 。12.产生式是用于定义 语法成分 的一种书写规则。 13.设 GS是给定文法,则由文法 G 所定义的语言 L(G)可描述为: L(G)x S=>*x,xVT* 。14.设 G 是一个给定的文法,S 是文法的开始符号,如果 Sx(其中 xV*),则称 x 是*文法的一个 句型 。15.设 G 是一个给定的文法,S 是文法的开始符号,如果 Sx(其中 xVT*),则称 x 是文*法的一个 句子 。16.扫描器的任务是从源程序中识别出一个个 单词符号 。 17.语法分析最常用的两类方法是 自上而下 和 自下而上 分析法。 18.语法分析的任务是识别给定的终结符串是否为给定文法的 句子 。 19.递归下降法不允许任一非终结符是直接 左 递归的。 20.自顶向下的语法分析方法的关键是 如何选择候选式 的问题。 21.递归下降分析法是自 顶向下 分析方法。 22.自顶向下的语法分析方法的基本思想是:从文法的 开始符号 开始,根据给定的输入 串并按照文法的产生式一步一步的向下进行直接推导,试图推导出文法的 句子 ,使 之与给定的输入串匹配。23.自底向上的语法分析方法的基本思想是:从给定的终结符串开始,根据文法的规则一步 一步的向上进行 直接归约 ,试图 归约 到文法的 开始符号 。24.自底向上的语法分析方法的基本思想是:从输入串入手,利用文法的产生式一步一步地 向上进行 直接归约 ,力求 归约 到文法的 开始符号 。26.在 LR(0)分析法的名称中,L 的含义是 自左向右的扫描输入串 ,R 的含义是 最左归约 ,0 的含义是向貌似句柄的符号串后查看 0 个输入符号 。 31.终结符只有 综合属性 ,它们由词法分析器提供。''32.在使用高级语言编程时,首先可通过编译程序发现源程序的全部 A(语法) 错误和 B(语义) 部分错误. 34一个句型中的最左简单短语称为该句型的_句柄_。 36从功能上说,程序语言的语句大体可分为_执行性_语句和说明性_语句两大类。 37语法分析是依据语言的_语法_规则进行的,中间代码产生是依据语言的_语义_规进 行的。 38语法分析器的输入是_单词符号_,其输出是_语法单位_。 40逆波兰式 ab+c+ d*e- 所表达的表达式为_(a+b+c)*d-c_ 。 41计算机执行用高级语言编写的程序主要有两种途径:_解释_和_编译_。 42自上而下分析法采用_移进_、归约、错误处理、接受_等四种操作。 43一个 LR 分析器包括两部分:一个总控程序和_一张分析表_。 44后缀式 abc-/所代表的表达式是 a/(b-c)_。 46语法分析基于_上下文无关_文法进行,即识别的是该类文法的句子。语法分析的有 效工具是_语法树_。 48语义分析阶段所生成的与源程序等价的中间表示形式可以有_逆波兰_、四元式表示 _与_三元式表示_等。51.自顶向下语法分析会遇到的主要问题有 左递归 和 回溯 。52.已知文法 GE:ET|E+T; TF|T*F; F(E)|i 该文法的开始符号是 ,终结符号集合 VT是 ,非终结符号结合 VN是 。''二、单选题二、单选题1一个编译程序中,不仅包含词法分析,( A),中间代码生成,代码优化,目标代码生成 等五个部分。A语法分析 B文法分析 C语言分析 D解释分析 2语法分析器则可以发现源程序中的(D )。 A语义错误 B语法和语义错误 C错误并校正 D语法错误 3解释程序处理语言时 , 大多数采用的是(B)B 方法。 A源程序命令被逐个直接解释执行 B先将源程序转化为中间代码 , 再解释执行 C先将源程序解释转化为目标程序 , 再执行 D以上方法都可以 4编译程序是一种(B)。 A汇编程序 B翻译程序C解释程序 D目标程序 5通常一个编译程序中,不仅包含词法分析,语法分析,中间代码生成,代码优化,目标 代码生成等五个部分,还应包括(C)。A模拟执行器 B解释器 C表格处理和出错处理 D符号执行器 6一个句型中的最左(B)称为该句型的句柄。A短语 B简单短语 C素短语 D终结符号 7文法 GE :ETETTFTFFa(E) 该文法句型 EF(ET)的简单短语是下列符号串中的(B)。 (ET) ET F F(ET) A 和 B 和 C 和 D 8词法分析器用于识别(C)。A句子 B句型 C单词 D产生式 9在自底向上的语法分析方法中,分析的关键是(D)。A寻找句柄 B寻找句型 C消除递归 D选择候选式 10文法 G 产生的( D)的全体是该文法描述的语言。A句型 B终结符集 C非终结符集 D句子 11若文法 G 定义的语言是无限集,则文法必然是(A)。 A递归的 B前后文无关的C二义性的 D无二义性的 12四种形式语言文法中,1 型文法又称为(C)C 文法。A短语结构文法 B前后文无关文法 C前后文有关文法 D正规文法 13一个文法所描述的语言是(A)。A唯一的 B不唯一的C可能唯一,好可能不唯一 D都不对 14(B)和代码优化部分不是每个编译程序都必需的。 A语法分析 B中间代码生成C词法分析 D目标代码生成 15(B)是两类程序语言处理程序。 A高级语言程序和低级语言程序B解释程序和编译程序 ''C编译程序和操作系统D系统程序和应用程序 16. 一个上下文无关文法 G 包括四个组成部分,它们是:一组非终结符号,一组终结符号, 一个开始符号,以及一组(D)。 A句子 B句型C单词 D产生式 17 文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 2 型文法是(D)。A短语文法 B正则文法 C上下文有关文法 D上下文无关文法 18文法 G 所描述的语言是(C)的集合。 A文法 G 的字母表 V 中所有符号组成的符号串 B文法 G 的字母表 V 的闭包 V* 中的所有符号串 C由文法的开始符号推出的所有终结符串 D由文法的开始符号推出的所有符号串 19文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 0 型文法是(A)。A短语文法 B正则文法 C上下文有关文法 D上下文无关文法 20(A 是一种典型的解释型语言。 ABASIC BC CFORTRAN DPASCAL 21与编译系统相比,解释系统(D)。 A比较简单 , 可移植性好 , 执行速度快 B比较复杂 , 可移植性好 , 执行速度 快 C比较简单 , 可移植性差 , 执行速度慢 D比较简单 , 可移植性好 , 执行速度 慢 22用高级语言编写的程序经编译后产生的程序叫(B)。 A源程序 B目标程序 C连接程序 D解释程序 23编写一个计算机高级语言的源程序后,到正式上机运行之前,一般要经过(B)这几步:(1) 编辑 (2) 编译 (3) 连接 (4) 运行 A(1)(2)(3)(4) B(1)(2)(3) C(1)(3) D(1)(4) 24把汇编语言程序翻译成机器可执行的目标程序的工作是由(B)完成的。A编译器 B汇编器 C解释器 D预处理器 25词法分析器的输出结果是(C)。A单词的种别编码 B单词在符号表中的位置 C单词的种别编码和自身值 D单词自身值 26 正规式 M 1 和 M 2 等价是指(C)。 AM1 和 M2 的状态数相等BM1 和 M2 的有向边条数相等 CM1 和 M2 所识别的语言集相等DM1 和 M2 状态数和有向边条数相等 27 文法 G:SxSx|y 所识别的语言是(C)。Axyx B(xyx)* C Dx*yx* )0( nyxxnn28如果文法 G 是无二义的,则它的任何句子 (A)。A最左推导和最右推导对应的语法树必定相同 B最左推导和最右推导对应的语法树可能不同C最左推导和最右推导必定相同 D可能存在两个不同的最左推导,但它们对应的语法树相同 29构造编译程序应掌握(D)。A源程序 B目标语言C编译方法 D以上三项都是 30四元式之间的联系是通过(B)实现的。 ''A指示器 B临时变量C符号表 D程序变量 31表达式(AB)(CD)的逆波兰表示为(B)。AABCD BABCD CABCD DABCD 33 编译程序是对(D)。 A汇编程序的翻译 B高级语言程序的解释执行 C机器语言的执行 D高级语言的翻译 34 采用自上而下分析,必须(C)。A消除左递归 B消除右递归C消除回溯 D提取公共左因子 35在规范归约中,用()B 来刻画可归约串。A直接短语 B句柄C最左素短语 D素短语 36间接三元式表示法的优点为(A)。 A采用间接码表,便于优化处理B节省存储空间,不便于表的修改 C便于优化处理,节省存储空间 D节省存储空间,不便于优化处理 37在目标代码生成阶段,符号表用(D)。A目标代码生成 B语义检查C语法检查 D地址分配 38下面关于解释程序的描述正确的是 B . (1) 解释程序的特点是处理程序时不产生目标代码 (2) 解释程序适用于 COBOL 和 FORTRAN 语言 (3) 解释程序是为打开编译程序技术的僵局而开发的 A. (1)(2) B. (1) C. (1)(2)(3) D.(2)(3)39.解释程序处理语言时,大多数采用的是 B 方法. A.源程序命令被逐个直接解释执行 B.先将源程序转化为中间代码,再解释执行 C.先将源程序解释转化为目标程序,在执行 D.以上方法都可以40.用不同语言编写的程序产生 后,可用 连接在一起生成机器可执行的程序.在机 器中真正执行的是 . 上面三空格对应的选项是:A a. 源程序 b. 目标程序 c. 函数 d. 过程 e. 机器指令代码 f. 模块 g. 连接程序 h.程序库 A. b、g、e B. b、c、e C. e、g、f D. e、c、f41.由于受到具体机器主存容量的限制,编译程序几个不同阶段的工作往往被组合成 , 诸阶段的工作往往是 进行的. 上面两空格对应的选项是: A a. 过程 b. 程序 c. 批量 d.遍e. 顺序 f. 并行 g. 成批 h.穿插 A. d 和 h B. d 和 e C. a 和 h D. a 和 e42.编译过程中,语法分析器的任务就是 B .(1)分析单词是怎样构成的 (2) 分析单词串是如何构成语句和说明的(3)分析语句和说明是如何构成程序的 (4) 分析程序的结构 A. (2)(3) B. (2)(3)(4) C. (1)(2)(3) D.(1)(2)(3)(4)43.编译程序必须完成的工作有 A .(1) 词法分析 (2) 语法分析 (3) 语义分析(4) 代码生成 (5) 中间代码生成 (6) 代码优化A. (1)(2)(3)(4) B. (1)(2)(3)(4)(5) C. (1)(2)(3)(4)(5)(6) D. (1)(2)(3)(4)(6) ''44按逻辑上划分,编译程序第二步工作是 C 。 A. 语义分析 B. 词法分析 C. 语法分析 D. 代码优化 45已知语言 L= xnyyn | n>=1,则下述文法中, D 可以产生语言 L。 A 1.ZxZy|xAy|y B 1.AxAy2. AxAy|x 2.Ax C 1.ZAyB D 1.ZxAy2.AxA|x 2.AxAy|y3.ByB|y 46乔姆斯基(Chomsky)把文法分为四种类型,即 0 型、1 型、2 型、3 型。其中 3 型文 法是 B 。 A.短语文法 B.正则文法 C.上下文有关文法 D.上下文无关文法 48设 G 是一个给定的文法,S 是文法的开始符号,如果 Sx(其中 xV*),则称 x 是文 法 G 的一个 B 。 A. 候选式 B. 句型 C. 单词 D. 产生式 49若一个文法是递归的,则它所产生的语言的句子 A 。 A.是无穷多个 B.是有穷多个 C.是可枚举的 D.个数是常量 50文法的二义性和语言的二义性是两个 A 的概念。 A 不同 B 相同 C 无法判断 D 不存在51.在语法分析处理中,FIRST 集合、FOLLOW 集合、SELECT 集合均是 B 。 A. 非终结符集 B.终结符集 C. 字母表 D. 状态集52.编译程序中语法分析器接收以 A 为单位的输入。 A. 单词 B. 表达式 C. 产生式 D. 句子53. 在 LR 分析法中,分析栈中存放的状态是识别规范句型 C 的 DFA 状态。 A.句柄 B. 前缀 C. 活前缀 D. LR(0)项目''三、是非题三、是非题(下列各题,你认为正确的,请在题干的括号内打“ ”,错的打“×”。) 1计算机高级语言翻译成低级语言只有解释一种方式。 (X) 2在编译中进行语法检查的目的是为了发现程序中所有错误。 (X) 3甲机上的某编译程序在乙机上能直接使用的必要条件是甲机和乙机的操作系统功能完全 相 同。 (X) 4“用高级语言书写的源程序都必须通过编译,产生目标代码后才能投入运行”这种说法。 (X) 5正则文法其产生式为 Aa,ABb, A,BVN,a、bVT。 (V) 6产生式是用于定义词法成分的一种书写规则。 (X) 7解释程序适用于 COBOL 和 FORTRAN 语言。 (X) 8正规文法产生的语言都可以用上下文无关文法来描述。 (V) 9如果一个文法存在某个句子对应两棵不同的语法树,则称这个文法是二义的。 (V) 10编译程序是对高级语言程序的解释执行。 (X) 11一个有限状态自动机中,有且仅有一个唯一的终态。 (X) 12语法分析时必须先消除文法中的左递归 。 (X) 13两个正规集相等的必要条件是他们对应的正规式等价。 (V ) 14设 r 和 s 分别是正规式,则有 L(r|s)=L(r)L(s)。 (X) 15确定的自动机以及不确定的自动机都能正确地识别正规集。 (V) 16词法分析作为单独的一遍来处理较好。 (X) 17构造 LR 分析器的任务就是产生 LR 分析表。 (V) 18编译程序与具体的机器有关,与具体的语言无关。 (X) 19每个文法都能改写为 LL(1)文法。 (X) 20递归下降法允许任一非终结符是直接左递归的。 (V) 21递归下降分析法是自顶向下分析方法。 (V) 22一个 LL(l)文法一定是无二义的。 (V) 23算符优先关系表不一定存在对应的优先函数。 (X) 24自底而上语法分析方法的主要问题是候选式的选择。 (X) 25LR 分析方法是自顶向下语法分析方法。 (X) 26简单优先文法允许任意两个产生式具有相同右部。 (X) 27若一个句型中出现了某产生式的右部,则此右部一定是该句型的句柄。 (X) 28一个句型的句柄一定是文法某产生式的右部。 (V) 29在 SLR(1)分析法的名称中,S 的含义是简单的。 (V) 30综合属性是用于 “ 自上而下 ” 传递信息。 (X) 31一个算符优先文法可能不存在算符优先函数与之对应。 (V) 32LR 分析法在自左至右扫描输入串时就能发现错误,但不能准确地指出出错地点。 (V) 33规范归约和规范推导是互逆的两个过程。 (V) 34LR 分析技术无法适用二义文法。 (X) 35逆波兰表示法表示表达式时无须使用括号。 (V) 36逆波兰法表示的表达式亦称后缀式 。 (V) 38在程序中标识符的出现仅为使用性的。 (X)''39.设为a,b,则 a,ba, 都是上的正规式。 (X)40.对于上下文无关文法 GS,若 SAB 则 A 一定是一条产生式规则,其中 ,(VTVN)*。 (X)41.对于逆波兰后缀式,无论从哪头开始分析均可得到唯一正确的分解。 (V)42.LR(0)分析法是一种规范归约法。(V)43.算符优先分析法只能用来分析算符优先文法。 (V)44.解释程序和编译程序一样,生成目标代码。 (X)45.编译程序生成的目标代码只能是机器语言。 (X)46.等价文法是指两个文法完全相同。 (X)47. 对于字母表 上的任一 NFA M',必存在 上与 NFA M' 等价的 DFA M。 (V)48. 每个文法都能改写为 LL(1)文法。 (X)49. 不存在正规文法能产生语言:L=anbn|n>=1(V)''四、简答题四、简答题1、什么是句子? 什么是语言?答: 设 G 是一个给定的文法,S 是文法的开始符号,如果 S=>*x(其中 xVt*) ,则称 x 是文法的一个句子。设 GS是给定文法,则由文法 G 所定义的语言 L(G)可描述为 L(G)xS=>*x,xVT*2、已知文法 GE为: ET|E+T|E-T TF|T*F|T/F F(E)|i 该文法的开始符号(识别符号)是什么? 请给出该文法的终结符号集合 VT和非终结符号集合 VN。 找出句型 T+T*F+i 的所有短语、简单短语和句柄。答: 该文法的开始符号(识别符号)是 E。该文法的终结符号集合 VT=+、-、*、/、 (、 ) 、i。 非终结符号集合 VN=E、T、F。 句型 T+T*F+I 的句柄为第一个 T。3、已知文法 GS为: SdAB AaA|a BBb| GS产生的语言是什么? GS能否改写为等价的正规文法?答: GS产生的语言是 L(GS)=danbmn1,m0。 GS能改写为等价的正规文法,其改写后的等价的正规文法 GS为: SdA A aA|aB|a B bB|b5、证明下面文法 GN是二义性文法。 GN: N SEE S SDDE 0210 D 012''7、简述 DFA 与 NFA 有何区别 ? 答:主要区别在于,1.DFA 没有 转换;2.DFA 的状态转换函数是单值映射,即当前状态 输入一个字符后转换到下一个状态,而 NFA 的状态转换函数是非单值映射,也就是说当前 状态输入一个字符后可以转换到下面 N 个状态。8、试给出非确定自动机的定义。 答:一个非确定的有穷自动机(NFA)M 是一个五元组:M=(S,move,s0 ,F) 。 其中: 1. 一个有限的状态集合 S; 2. 是一个输入符号集合, 不在 中; 3. move 是状态转换函数,是在 S×*S 的子集的映射,即,move: S×*2S ; 表明在某状态下对于某输入符号可能有多个后继状态; 4. s0 是唯一的开始状态; 5. F 是接受(或终止)状态集合,且 F 属于 S 一个子集。9、为正规式(a|b)*a(a|b) 构造一个等价的确定的有限自动机。 答:10、构造正规式相应的 NFA : 1(0|1)*101 12、已知文法 GS 为:SdAB AaA|aBBb|GS 产生的语言是什么? 13、编译过程一般分为几个阶段?各阶段的输入输出分别为什么?''15、在 LL(1)分析法中,LL 分别代表什么含义? 答:第一个 L 代表从左到右的扫描,第二个 L 代表每次进行最左推导。16、文法 G 为:SaABAaB |则判断 G 为 LL(1)文法的条件是:17、文法 G=(A, B, S, a, b, c, P, S)其中 P 为:SAc|aBAabBbc该文法是二义的吗?说明理由。18、文法 G=(E, +, *, i, (, ), P, E)其中 P 为:EiEE+EEE*EE(E)该文法是二义的吗?说明理由。''19、自顶向下分析思想是什么? 答: 从开始符出发导出句型并一个符号一个符号地与给定终结符串进行匹配。如果全部匹配成 功,则表示开始符号可推导出给定的终结符串。因此判定给定终结符号串是正确句子。25、简单优先方法基本思想是什么? 28、语法制导翻译方法的基本思想是什么? 33、给定下列中缀式,分别写出等价的后缀式和四元式(运算符优先级按常规理解)。 (1)(ab*c)/(ab)d

    注意事项

    本文(编译知识学习原理小题'答案库.doc)为本站会员(一***)主动上传,得力文库 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知得力文库 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于得利文库 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

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

    工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

    © 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

    黑龙江省互联网违法和不良信息举报
    举报电话:0468-3380021 邮箱:hgswwxb@163.com  

    收起
    展开