- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 “C0编译器”案例概述 本章要点 3.1 编译原理简介 语言是人与人之间传递信息的媒介和手段。在计算机领域,程序设计语言充当了人与问题和协助解决该问题的计算机之间的接口和工具。但是用高级语言编写的程序,计算机是不能立即执行的,必须通过一个翻译程序的加工,使之转变成为与之等价的机器语言程序,机器才能执行。这种翻译程序,称之为编译程序。 为一种具体语言构造一个编译程序是件很复杂的任务,编译过程的复杂性在很大程度上取决于源语言。编译程序必须完成两个主要任务:一是源程序的分析,二是目标程序的综合。 编译器一般包括以下几个方面: 词法分析 语法分析 语义分析 代码生成 代码优化 符号表管理 错误的检测和处理 3.2 C0语言和目标代码定义 “C0编译器”是根据给定的C0文法实现编译器,产生某虚拟计算机的目标代码,并编写解释执行程序,对该目标代码进行解释执行,输出解释执行结果。总的来说,它需要实现以下几个功能: 对C0语言进行编译并输出相应编译信息; 生成目标代码并保存; 执行程序并输出执行结果。 所谓的C0语言,是对C语言的一种简化,基本符合L0文法规则(一处定义除外),并按照BNF范式结构进行描述。 “C0编译器”首先将C0语言进行编译,形成目标代码。这里的目标代码,是模拟80X86下的汇编语言定义的指令系统,包含26条指令,每个指令有0至2个参数。 “C0编译器”还负责在虚拟机器环境中将目标代码进行解释执行,并输出最终结果。 3.3 “C0编译器”程序结构 “C0编译器”可以分成两个相对独立的部分,一部分负责C0语言的编译和目标代码生成,另一部分负责目标代码的解释执行和结果输出。 语法分析作为前半部分的核心,通过调用词法分析从源程序读取单词,并与符号表处理和出错处理进行交互,进而调用代码生成; 后半部分通过读取目标代码,并模拟内存栈进行程序的解释执行。 由于C0语言基本符合L0文法,因此采用递归下降法实现编译,在唯一一处例外情况下可以采用预读一位的方式予以解决。在详细设计上,程序共包含30个函数,分别负责具体功能的实现。 程序采用C++语言实现,开发环境为VC6.0,以控制台作为交互方式。 本章习题 什么是编译程序,包含哪些主要内容? 尝试用给出的BNF范式描述,书写一段C0语言源代码。 C0编译器程序的体系结构是什么,主要函数有哪些? C0编译器运行栈的运行机制是什么?
您可能关注的文档
最近下载
- 2023年蚌埠市从优秀村(社区)干部中考试录用乡镇机关公务员加分考试真题及答案.pdf VIP
- 【教学创新大赛】《数字信号处理》教学创新成果报告.docx
- 学习领会二十届中央纪委四次全会上重要讲话心得体会.docx VIP
- 各类骨折病人的体位护理.pptx VIP
- 2023年标准化知识题库带答案.pdf
- 黑龙江 2023年肿瘤放射治疗学主治医师考试:肿瘤放射治疗学专业知识真题模拟汇编(共769题).doc VIP
- 浅谈网络购物环境下消费者权益的保护.docx VIP
- 2024年湖南交通职业技术学院单招职业技能测试题库及答案解析.docx VIP
- 9年级体育教案.pdf VIP
- 《田间试验统计》课件——项目三 试验数据调查取样.pptx VIP
文档评论(0)