- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理结构框图
一个典型的编译程序通常由哪些部分组成?各部分的主要功能是什么?
答:一个典型的编译程序通常包含8个组成部分,它们是词法分析程序、语法分析程序、语义分析程序、中间代码生成程序、中间代码优化程序、目标代码生成程序、表格管理程序和错误处理程序。其各部分的主要功能简述如下。
词法分析程序:从左到右扫描源程序,识别单词及其相关属性
语法分析程序:分析源程序的结构,判别它是否为相应程序设计语言中的一个合法程序
语义分析程序:审查源程序有无语义错误,为代码生成阶段收集类型信息?
中间代码生成程序:将源程序变成一种内部?表示形式。
代码优化程序:对中间代码进行变换或改造,使生成的代码更为高效
目标代码生成程序:把中间代码变成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码
表格管理程序:负责建立、填写和查找等一系列表格工作。
错误处理程序:处理和校正源程序中存在的词法、语法和语义错误。
注意:如果问编译程序有哪些主要构成成分,只要回答六部分就可以。如果搞不清楚,就回答八部分。
什么是解释程序?它与翻译程序的主要不同是什么?
答:解释程序接受某个语言的程序并立即运行这个源程序。它的工作模式是一个个的获取、分析并执行源程序语句,一旦第一个语句分析结束,源程序便开始运行并且生成结果,它特别适合程序员交互的工作情况,而编译程序是一个语言处理程序,它把一个高级语言程序翻译成某个机器的汇编或二进制代码程序,这个二进制代码程序在机器上运行以生成结果。
它们的主要不同在于:解释程序是边解释边执行,解释程序运行结束即可得到该程序的运行结果,而编译程序只是把源程序翻译成汇编或者二进制程序,这个程序再执行才能得到程序的运行结构。
符号和符号串
字母表:字母表是元素的非空有穷集合,我们把字母表的中的元素称为符号,因此字母表也称为符号集
符号串:由字母表中的符号组成的任何有穷序列称为符号串,字母表A={a,b,c}上的符号串有:a,b,c,ab,aaca.
一个的4个组成部分
文法G定义为四元组(VN,VT,P,S)
VN:非终结符集
VT:终结符集
P:规则的集合
S:识别符或开始符
典型例题及解答
证明文法G=({E,O},{(,),+,*,v,d},P,E)是二义的
E→EOE|(E)|v|d
O→+|*
解:对于句子v*v+d的语法树不止一棵,如图3.7和图3.8
所以该文法是二义的
写一文法,使其语言是偶正整数的集合。?要求:
?(1)?允许0打头;??
(2)不允许0打头。
答案:
(1)允许0开头的偶正整数集合的文法???
E→NT|D???
T→NT|D
?N→D|1|3|5|7|9???
D→0|2|4|6|8
(2)不允许0开头的偶正整数集合的文法??
?E→NT|D????
T→FT|G????
N→D|1|3|5|7|9???
D→2|4|6|8???
F→N|0???
G→D|0?
给出生成下述语言的三型文法:
解释
原创力文档


文档评论(0)