编译原理及其习题解答(武汉大学出版社)课件chap1.ppt_第1页
编译原理及其习题解答(武汉大学出版社)课件chap1.ppt_第2页
编译原理及其习题解答(武汉大学出版社)课件chap1.ppt_第3页
编译原理及其习题解答(武汉大学出版社)课件chap1.ppt_第4页
编译原理及其习题解答(武汉大学出版社)课件chap1.ppt_第5页
已阅读5页,还剩72页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1,课程内容,第一章 引论 第二章 形式语言概论 第三章 有穷自动机 第四章 词法分析 第五章 自上而下语法分析 第六章 自下而上分析和优先分析方法 第七章 自下而上的LR(k)分析方法 第八章 语法制导翻译 代码优化 ,2,与课程有关的问题:,本课程的性质、目的和任务 : 本课程是计算机类专业的专业课,目的是使学生了解并掌握编译程序的基本理论和方法,具有分析和实现编译程序的初步能力。 本课程的基本要求 : 通过对本课程的学习,对形式语言有初步了解,并能对编译程序的整个结构有较清楚地了解,熟悉和掌握几种主要编译方法。 课程内容的重点、深度与广度 : 文法和形式语言、词法分析和有穷自动机、语法分

2、析、语义分析、目标代码的生成,此外还要求掌握和了解符号表的构造、存储分配与管理、代码优化和错误校正。,3,参考书:,编译原理教程 胡元义等西安电子科大 程序设计语言编译原理陈火旺、刘春林等 国防工业出版社 编译原理 吕映芝等 清华出版社 Kenneth C Louden Compiler Construction Principles and Practice 编译原理与实践, PWS Publishing Company, 1997。中译本 机械工业出版社 Alfred V. Aho, Monica S. Lam, Ravi Sethi, Jeffrey D. Ullman Compiler

3、s: Principles, Techniques, and Tools (2nd Edition), Addison Wesley, 2006 (Dragon book,龙书) Andrew W. Appel Modern Compiler Implementation in Java, CambridgeUniversity Press, 2002. 2nd Ed. (Tiger Book,虎书) Michael L. Scott Programming Language Pragmatics, Second Edition,Morgan Kaufmann, 2005. (中译本: 程序设

4、计语言:实践之路裘宗燕,电子工业出版社),4,第一章 引 论,本节内容: 程序的翻译 编译程序的工作过程 编译程序的结构 编译程序的组织方式 编译程序的构造,5,编译程序在计算机系统中的位置,分类 软件 系统软件 语言处理系统,6,1.1 程序的翻译,1.1.1 程序设计语言 机器语言 001110010010 汇编语言 add R1 2 高级语言 begin x:=9+2 end 问题: 计算机只能识别二进制数0、1表示的指令和数构成的本计算机系统的机器语言。如何让计算机执行高级语言程序呢?,7,1.1 程序的翻译,1.1.2 翻译程序 所谓翻译程序,是指这样一种程序,它能将用甲语言(源语言

5、)编写的程序翻译成与之等价的用乙语言(目标语言)书写的程序。 程序的翻译通常有两种方式:一是“编译”方式,二是“解释”方式。,8,1.1 程序的翻译,1.1.3 编译方式 一种分阶段进行的方式 1.翻译阶段: 高级语言或汇编语言源程序 机器语言目标程序 2.运行阶段 目标程序、运行子程序、数据 运行结果,9,1.1 程序的翻译,3.编译方式的特点 在编译方式下,源程序的执行需要分阶段。 如果目标程序是机器语言程序, 则源程序的执行分为两大阶段:编译阶段和运行阶段。 如果目标程序是汇编语言程序, 则源程序的执行分为三大阶段:编译阶段、汇编阶段和运行阶段。 编译方式下,生成了目标代码,且可多次执行

6、。,10,1.1 程序的翻译,4.关于编译程序的几点说明 编译程序生成的目标程序不一定是机器语言的程序,也有可能是汇编语言程序; 编译程序与具体的机器和语言有关,即任何一个具体的编译程序都是某一特定类型的计算机系统中关于某一特定语言的编译程序; 对编译程序而言,源程序是输入数据,目标程序是输出结果。,11,预处理器,编译器,汇编器,装配连接编辑,骨架程序,源程序,目标汇编程序,可重定位机器代码,绝对机器码,可重定位目标文件库,一个语言处理系统,12,不同的语言有不同的编译程序,语言转换系统,C+编译器,C+,C,Java,Bytecode,Java编译器,13,1.1 程序的翻译,1.1.4

7、解释方式 完成解释工作的解释程序将按源程序中语句的动态顺序,逐句地进行分析解释,并立即予以执行。 执行历程为:,14,1.1 程序的翻译,源程序解释执行的历程 源程序 (高级语言)、初始数据 解释程序 计 算 结 果 在解释方式下,并不生成目标代码,而是直接执行源程序本身。这是编译方式与解释方式的根本区别。,15,1.1 程序的翻译,1.1.5 程序设计语言的分类 汇编语言 命令式语言:Fortran, Algol, Pascal, Basic, C, Modula,Ada, 面向对象语言:Simula, Smalltalk, C+, Java, C#, 说明式语言: 函数式语言:Lisp,

8、Scheme, ML, Haskell, 逻辑程序设计语言:Prolog 脚本语言:Shell, Awk, Perl, Tcl, Python, Javascript, PHP, 文字处理语言:TEX, LATEX(本幻灯片用此编写); 超文本语言:HTML, XML; 数据库语言:SQL; 数据表处理语言:VisiCalc, Lotus1-2-3, Excel,16,1.2 编译程序的工作过程,词法分析 语法分析 语义分析和中间代码生成 中间代码优化 目标代码生成,17,1.2 编译程序的工作过程,1.2.1 词法分析 依据语言词法规则,分析由字符组成的源程序,把它识别为一个一个具有独立意义

9、的最小语法单位,即“单词”,并识别出与其相关的属性(如是标识符,是界限符,还是数,等等),再转换成长度上统一的标准形式(这种统一的标准形式既刻画了单词本身,又刻画了它所具有的属性,称为属性字),以供其它部分使用。,18,词法分析,读字符流的源程序、识别单词 例: position = initial + rate * 60,19,词法分析,单词类型单词值 标识符1(id1)position 算符(赋值) = 标识符2(id2) initial 算符(加) + 标识符3(id3) rate 算符(乘) * 整数 60 分号 ;,20,1.2 编译程序的工作过程,1.2.2 语法分析 依据语法规则

10、,逐一分析词法分析时得到的单词,把单词串分解成各类语法单位,即确定它们是怎样组成说明和语句,以及说明和语句又是怎样组成程序的。分析时如发现有不合语法规则的地方,便将出错的位置及出错性质打印报告给程序员;如无语法错误,则用另一种中间形式给出正确的语法结构,供下一阶段分析使用。,21,语法分析,功能:层次分析,把源程序的单词序列组成语法短语(表示成语法树). 例: :=“=” :=“+” :=“*” :=“(”“)” := := :=,22,赋值语句,标识符,表达式,表达式,+,表达式,表达式,标识符,常数,标识符,=,表达式,*,23,语法分析id1=id2+id3*N,24,1.2 编译程序的

11、工作过程,1.2.3 语义分析 依据语言的语义规则对语法分析得到的语法结构进行静态语义检查(确定类型、类型和运算合法性检查、识别含义与相应的语义处理及其它一些静态语义检查),并用另一种内部形式表示出来,或者直接用目标语言表示出来。 凡在编译时可以确定的内容称为“静态”的;凡必须推迟到程序运行时才能确定的内容称为“动态”的。,25,语义分析,语义审查(静态语义) 上下文相关性 类型匹配 类型转换,例:Program p(); Var rate:real; procedure initial; position := initial + rate * 60 /* error */ /* error

12、 */ /* warning */; ,26,Program p(); Var rate:real; Var initial :real; Var position :real ; position := initial + rate * 60 ,27,语义分析,28,中间代码生成,源程序的内部(中间)表示 三元式、四元式、P-Code、C-Code、U-Code、bytecode,29,中间代码生成,id1= id2 + id3 * 60 (1)(inttoreal,60-t1) (2)(*,id3t1t2) (3)(+,id2t2t3) (4)(=,t3-id1),30,1.2 编译程序的

13、工作过程,1.2.4 代码优化 依据程序的等价变换规则,尽量压缩目标程序运行所需的时间和所占的存储空间,以提高目标程序的质量。,31,代码优化,id1= id2 + id3 * 60 (1)(inttoreal60-t1) (2)( * id3t1t2) (3)( +id2t2t3) (4)( :=t3-id1) 变换 (1) ( *id360.0t1) ( 2)( + id2 t1id1),32,1.2 编译程序的工作过程,1.2.5 代码生成 如果语义分析时把源程序表示成中间形式而不是表示成目标指令,则由本部分完成从中间形式到目标指令的转换。如果语义分析时,已直接生成目标指令,则无需另外再

14、做代码生成工作。 目标指令可能是绝对指令代码,或可重新定位的指令代码或汇编指令代码。该阶段的工作有赖于硬件系统结构和机器指令含义。,33,目标代码生成,(*,id360.0t1) (+,id2t1id1),movfid3,R2 mulf#60.0,R2 movfid2,R1 addfR2,R1 movfR1,id1,34,1.2 编译程序的工作过程,1.2.6 表格管理 登记源程序中出现的每个名字以及名字的各种属性。有些名字的属性需要在各个阶段才能填入。,35,符号表管理,记录源程序中使用的名字 收集每个名字的各种属性信息 类型、作用域、分配存储信息,Const1常量值:35 Var1变量类型

15、:实层次:2,36,1.2 编译程序的工作过程,1.2.7 出错处理 源程序中的错误有语法错误和语义错误两种。 1.语法错误:源程序中不符合语法(或词法)规则的错误,它们可在词法分析或语法分析时检测出来。 2.语义错误:源程序中不符合语义规则的错误,一般在语义分析时检测出来,有的语义错误要在运行时才能检测出来。通常包括:说明错误、作用域错误、类型不一致等等,37,出错处理,检查错误、报告出错信息、排错、恢复编译工作,38,1.3 编译程序的结构,39,1.3 编译程序的结构,40,1.4 编译程序的组织形式,1.4.1 遍(趟,趟程) 所谓一趟或一遍是指一个编译程序在编译时刻把源程序或源程序的

16、等价物(中间程序)从头到尾扫描一遍并转换成另一紧邻的等价物的全过程。 根据编译程序在完成翻译任务的过程中需要对源程序或其中间等价物扫描的遍数,可以把编译程序分为单遍扫描的编译程序(只需扫描一遍)和多遍扫描的编译程序(需扫描多遍)。,41,单遍扫描的编译程序,42,1.4 编译程序的组织形式,1.4.2 编译的前端和后端 前端主要由与源语言有关但与目标机器无关的那些部分组成,如词法分析、语法分析、语义分析与中间代码生成及部分代码优化工作。 后端主要包括编译中与目标机器有关的那些部分,如与目标机有关的代码优化和目标代码生成等。后端不依赖于源语言而仅依赖于中间语言。 可以通过改变编译程序的后端来实现

17、编译程序的移植。,43,1.5 编译程序的构造,1.5.1 高级语言的自编译性 构造编译程序可以用机器言语、汇编语言和高级语言。 高级语言的自编译性:一个语言可以用来编写自己的编译程序。,44,1.5 编译程序的构造,1.5.2 编译的自展技术 通过一系列自展途径而形成编译程序的过程。 先对语言的核心部分构造一个小小编译程序(可用低级语言实现),再以它为工具构造一个能够编译更多语言成分的较大编译程序。如此扩展下去,越滚越大,最后形成所期望的整个编译程序。,45,1.5 编译程序的构造,1.5.3 编译的自展技术 将一个机器(宿主机)上的一个具有自编译性的高级语言编译程序移植到另一个机器(目标机

18、)上。 利用A机器上的高级语言L编写能在B机器上运行的高级语言L的编译程序。 如图:,46,1.5 编译程序的构造,1.5.3 编译的自展技术 将一个机器(宿主机)上的一个具有自编译性的高级语言编译程序移植到另一个机器(目标机)上。 利用A机器上的高级语言L编写能在B机器上运行的高级语言L的编译程序。,47,第1章内容小结, 什么是编译程序 编译方式的特点 解释方式的特点 编译方式与解释方式的根本区别 编译程序的工作过程 编译程序的结构 遍与编译程序的组织形式 编译程序的构造方法,48,结束,再见,复习 预习,49,1。1 什么是编译程序,功能,术语 源语言(程序) 目标语言(程序) 实现语言

19、,50,编译程序结构,词法分析程序 语法分析程序 语义分析程序 中间代码生成程序 代码优化程序 目标代码生成程序 符号表管理程序 出错管理程序,51,编译阶段的组合,分析,综合 源程序的分析 线性分析 层次分析 语义分析 目标程序的综合 编译的前端(front end) 编译的后端(back end) 遍(趟)从头到尾扫描源程序(各种形式)一遍,52,高级语言解释系统(basic,lisp,prolog),功能 让计算机执行高级语言 与编译程序的不同 1)不生成目标代码 2)能支持交互环境 (同增量式编译系统) 源 程 序 初始数据,解释程序,计算结果,53,解释系统,直接对源程序中的语句进行

20、分析,执行其隐含的操作。 如: b := 2 ; a := b+2 ; 编译程序 write a ; 解释程序直接将4的值输出(显示),Int 2 St b Ld b add 2 St a,生成代码,54,编译阶段和运行阶段存储结构,编译时 运行时,名字表,目标代码缓冲区,编译用源程序中 间表示各种表格,目标代码区,数据区,源程序缓冲区,55,解释系统存储结构,56,1.3 编译技术的发展和应用,功能:程序 集成环境 实现方式 手工 机器语言 汇编 系统程序设计语言 自动构造工具lex yacc gcc,57,编译程序的发展,计算模式,语言范式 语言应用领域,编译程序,万诺曼机体系结构 并行体

21、系结构 嵌入系统,58,编译程序的发展,语言范式 命令式(imperative language) 应用式(applicative) 基于规则的(rule-based) 面向对象的(object-oriented) 编译程序执行环境 批处理 交互环境 嵌入系统环境,59,语言模式(支持的计算模式),命令式: 程序特点: 语言执行的解释: 编译技术发展快: 语句1; 改变机器状态 系统语言 语句2; 内存 自动化生成技术 语句3; 各种寄存器 的内容 外存 与万诺曼机的 体系结构一般,60,应用式(函数式): 程序特点: Function n(funetion2(funetion1(data)

22、程序执行: 执行一个个函数施用在数据上的变换最终得到的结果 编译: 语法分析容易; 语义处理复杂;,61,基于规则的语言(prolog,yacc): 程序特点: 使能条件1 动作1 使能条件2 动作2 使能条件3 动作3 面向对象语言: 抽象数据类型,继承机制 编译: 动态绑定;,62,执行环境,批处理环境:将源程序作为整体处理 排除程序错误不能依靠用户的外部帮助 交互环境:解释 增量式编译 嵌入式系统环境:交叉编译 分布并行环境:并行编译 程序创建和测试环境: 独立编译 编译和调试同时设计考虑,63,编译技术的发展和应用,结构化编译器 程序分析工具 静态分析 动态分析 度量工具 结构度量 模

23、块接口复杂度 c分析工具(source insight) 广泛的语言领域 数据库系统查询 脚本语言 置标语言(SGML.HTML.XML),64,研究领域,并行编译技术 交叉编译技术 硬件描述语言及其编译技术,65,并行化编译技术,目的:提高并行计算机体系结构的性能。 超大规模计算的日益增长的需求 高性能计算机 并行软件,并行体系结构,单机速度,并行体系结构,途 径 1,途 径 2,66,并行体系结构 编译技术支持 串行程序并行化 编译技术支持 并行程序设计语言编译 依赖于目标机的优化(低层),性 能 发 挥,67,并行算法复杂,难掌握,难编程 开发并行 软件的困难 并行程序的不确定行为,难调

24、 试,验证 设计新的并行算法 修改已有串行程序尽量 (直接用并行程序 并行化(研究算法和 设计语言和并行程 应用的人同时工作) 序库实现。). HPF.Occom. PVM,途 径,1,2,嵌入式,交叉编译器,由于目标机指令系统与宿主机的指令系统不同,编译时将应用程序的源程序在宿主机上生成目标机代码,称为交叉编译。,O,A,B,交叉编译前后端,交叉编译前端,(依赖于目标机M的交叉编译)后端,中间代码,研究内容,多种语言,A d a,C+,Java,.,预 编 译,交 叉 编 译 器,C,72,硬件描述语言及其编译技术,电路设计依据 验证结果 如:VHDL,73,参考书,Tomas Pittmn

25、, The art of Compiler Design theory and Practice, Prentice-Hall 1992 Charles N. Fischer, Richard J. Leblanc, Crafting A Compiler, The Benjamin/Cummings Publishing Company 1988 ALFRED V. AHO, RAVISETHI, JEFFREY D. ULLMAN, Compilers Principles, Techniques and Tools ADDISSON-WESLEY 1986 陈火旺 java, GNU gcc.,74,参考

温馨提示

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

评论

0/150

提交评论