编译原理第三版 第一章 引论PPT教学课件
- 格式:ppt
- 大小:290.00 KB
- 文档页数:35
第一章 引 论第一章 引论1.1 1.1 什么叫编译程序什么叫编译程序编译程序编译程序::是指这样的程序,它能够把某种语言的程序转换成另一种语言的程序,而后者与前者在逻辑上是等价的。
如果源语言是诸如源语言是诸如FORTRAN FORTRAN FORTRAN、、Pascal Pascal、、C 、Ada Ada、、Smalltalk Smalltalk或或Java Java这样的这样的“高级语言”,而目标语言如汇编语言之类的“低级语言”这样的翻译程序则称之为编译程序。
本课程主要介绍设计和构造编译程序本课程主要介绍设计和构造编译程序的基本原理和方法。
编译程序又简称为“编译器”•第一个编译器是20世界50年代的后期出现的FORTRAN语言编译器。
•同样,解释程序又简称为“解释器”,但是在概念上与编译器有明显区别:编译程序是源转换系统,而解释程序是源程序的一个执行系统。
编译程序的结果是得到等价源程序的某种目标机程序,而解释程序的结果是得到源程序的执行结果,即它相当于执行源程序的抽象机。
第一章引论注意编译程序与解释程序的区别,一个语言的解释程序是这样的程序:它以该语言写的源程序作为输入,但不产生目标程序,而是边解释边执行源程序本身。
术语“编译”的内涵是实现从源语言表示的 术语算法向目标语言表示的算法的等价变换。
第一章引论高级语言分类及其编译:过程式语言:FORTRAN Pascal Ada C (特点:面向驱动,面向语句,由系列的语句组成)函数式语言:LISP ML ASL(注重程序表示的功能,而不是一个语句接一个语句的执行)从已有的函数出发构造更复杂的函数。
逻辑式语言:PROLOG(检查一定的条件,当满足时,则执行适当的动作。
)对象式语言:SMALLTALK C++(封装性、继承性、多态性)第一章引论这里主要研究过程式语言的编译高级语言分类及其编译:过程式语言:FORTRAN Pascal ADA C函数式语言:LISP ML ASL逻辑式语言:PROLOG对象式语言:SMALLTALK C++函数式语言与逻辑式语言,特别是逻辑式语言,其编译技术与过程式语言的差别比较大;因对象式语言的载体基本上是过程式的,所以其编译程序也不难理解。