现代编译原理-C语言描述

当前位置:首页 > 计算机网络 > 计算机理论 > 现代编译原理-C语言描述

出版社:人民邮电出版社
出版日期:2006-4
ISBN:9787115145529
作者:(美)安佩尔
页数:385页

作者简介

《现代编译原理:C语言描述》全面讲述了现代编译器的结构、编译算法和实现方法,是Andrew w.Apple的“虎书”——Modern Compiler Implementation——“红、蓝、绿”三序列之一。这三本书的内容基本相同。但是使用不同的语言来实现书中给出的一个编译器。本书使用的是更适合广大读者的c语言,而另外两本书分别采用ML语言和Java语言。本书的另一个特点是增加了一些其他编译原理教科书没有涉及的内容。前端增加了面向对象的程序设计语言、函数式程序设计语言等现代语言的编译实现方法,后端增加了针对现代计算机体系结构特征的一些比较成熟的优化方法。这部分内容展现了现代商业编译器需解决的一些关键问题,开拓了学生的视野,为学生未来进行更深入的研究奠定了基础。

《现代编译原理:C语言描述》全面讲述了现代编译器的各个组成部分,包括词法分析、语法分析、抽象语法、语义检查、中间代码表示、指令选择、数据流分析、寄存器分配以及运行时系统等。全书分成两部分,第一部分是编译的基础知识,适用于第一门编译原理课程(一个学期);第二部分是高级主题,包括面向对象语言和函数语言、垃圾收集、循环优化、ssA(静态单赋值)形式、循环调度、存储结构优化等,适合于后续课程或研究生教学。书中专门为学生提供了一个用C语言编写的实习项目,包括前端和后端设计,学生可以在一学期内创建一个功能完整的编译器。

书籍目录

第一部分 编译基本原理
第1章 绪论
1.1 模块与接口
1.2 工具和软件
1.3 树语言的数据结构
程序设计:直线式程序解释器
推荐阅读
习题
第2章 词法分析
2.1 词法单词
2.2 正则表达式
2.3 有限自动机
2.4 非确定有限自动机
2.4.1 将正则表达式转换为NFA
2.4.2 将NFA转换为DFA
2.5 Lex:词法分析器的生成器
程序设计:词法分析
推荐阅读
习题
第3章 语法分析
3.1 上下文无关文法
3.1.1 推导
3.1.2 语法分析树
3.1.3 二义性文法
3.1.4 文件结束符
3.2 预测分析
3.2.1 FIRST集合和FOLLOW集合
3.2.2 构造一个预测分析器
3.2.3 消除左递归
3.2.4 提取左因子
3.2.5 错误恢复
3.3 LR分析
3.3.1 LR分析引擎
3.3.2 LR(0)分析器生成器
3.3.3 SLR分析器的生成
3.3.4 LR(1)项和LR(1)分析表
3.3.5 LALR(1)分析表
3.3.6 各类文法的层次
3.3.7 二义性文法的LR分析
3.4 使用分析器的生成器
3.4.1 冲突
3.4.2 优先级指导
3.4.3 语法和语义
3.5 错误恢复
3.5.1 用error符号恢复
3.5.2 全局错误修复
程序设计:语法分析
推荐阅读
习题
第4章 抽象语法
4.1 语义动作
4.1.1 递归下降
4.1.2 Yacc生成的分析器
4.1.3 语义动作的解释器
4.2 抽象语法分析树
4.2.1 位置
4.2.2 Tiger的抽象语法
程序设计:抽象语法
推荐阅读
习题
第5章 语义分析
5.1 符号表
5.1.1 多个符号表
5.1.2 高效的命令式风格符号表
5.1.3 高效的函数式符号表
5.1.4 Tiger编译器的符号
5.1.5 函数式风格的符号表
5.2 Tiger编译器的绑定
5.3 表达式的类型检查
5.4 声明的类型检查
5.4.1 变量声明
5.4.2 类型声明
5.4.3 函数声明
5.4.4 递归声明
程序设计:类型检查
习题
第6章 活动记录
6.1 栈帧
6.1.1 帧指针
6.1.2 寄存器
6.1.3 参数传递
6.1.4 返回地址
6.1.5 栈帧内的变量
6.1.6 静态链
6.2 Tiger编译器的栈帧
6.2.1 栈帧描述的表示
6.2.2 局部变量
6.2.3 计算逃逸变量
6.2.4 临时变量和标号
6.2.5 两层抽象
6.2.6 管理静态链
6.2.7 追踪层次信息
程序设计:栈帧
推荐阅读
习题
第7章 翻译成中间代码
7.1 中间表示树
7.2 翻译为树中间语言
7.2.1 表达式的种类
7.2.2 简单变量
7.2.3 追随静态链
7.2.4 数组变量
7.2.5 结构化的左值
7.2.6 下标和域选择
7.2.7 关于安全性的劝告
7.2.8 算术操作
7.2.9 条件表达式
7.2.10 字符串
7.2.11 记录和数组的创建
7.2.12 while循环
7.2.13 for循环
7.2.14 函数调用
7.3 声明
7.3.1 变量定义
7.3.2 函数定义
7.3.3 片段
程序设计:翻译成树
习题
第8章 基本块和轨迹
8.1 规范树
8.1.1 ESEQ的转换
8.1.2 一般重写规则
8.1.3 将CALL移到顶层
8.1.4 线性语句表
8.2 处理条件分支
8.2.1 基本块
8.2.2 轨迹
8.2.3 完善
8.2.4 最优轨迹
推荐阅读
习题
第9章 指令选择
9.1 指令选择算法
9.1.1 Maximal Munch算法
9.1.2 动态规划
9.1.3 树文法
9.1.4 快速匹配
9.1.5 覆盖算法的效率
9.2 CISC机器
9.3 Tiger编译器的指令选择
9.3.1 抽象的汇编语言指令
9.3.2 生成汇编指令
9.3.3 过程调用
9.3.4 无帧指针的情形
程序设计:指令选择
推荐阅读
习题
第10章 活跃分析
10.1 数据流方程的解
10.1.1 活跃性计算
10.1.2 集合的表示
10.1.3 时间复杂度
10.1.4 最小不动点
10.1.5 静态活跃性与动态活跃性
10.1.6 冲突图
10.2 Tiger编译器的活跃分析
10.2.1 图
10.2.2 控制流图
10.2.3 活跃分析
程序设计:构造流图
程序设计:活跃分析模块
习题
第11章 寄存器分配
11.1 通过简化进行着色
11.2 合并
11.3 预着色的结点
11.3.1 机器寄存器的临时副本
11.3.2 调用者保护的寄存器和被调用者保护的寄存器
11.3.3 含预着色结点的例子
11.4 图着色的实现
11.4.1 传送指令工作表的管理
11.4.2 数据结构
11.4.3 程序代码
11.5 针对树的寄存器分配
程序设计:图着色
推荐阅读
习题
第12章 整合为一体
程序设计:过程入口/出口
程序设计:创建一个可运行的编译器
第二部分 高级主题
第13章 垃圾收集
13.1 标记-清扫式收集
13.2 引用计数
13.3 复制式收集
13.4 分代收集
13.5 增量式收集
13.6 Baker算法
13.7 编译器接口
13.7.1 快速分配
13.7.2 数据布局的描述
13.7.3 导出指针
程序设计:描述字
程序设计:垃圾收集
推荐阅读
习题
第14章 面向对象的语言
14.1 类
14.2 数据域的单继承性
14.3 多继承性
14.4 测试类成员关系
14.5 私有域和私有方法
14.6 无类语言
14.7 向对象程序的优化
程序设计:OBJECT Tiger
推荐阅读
习题
第15章 函数式程序设计语言
15.1 一个简单的函数式语言
15.2 闭包
15.3 不变的变量
15.3.1 基于延续的……I/O226
15.3.2 语言上的变化
15.3.3 纯函数式语言的优化
15.4 内联扩展
15.5 闭包变换
15.6 高效的尾递归
15.7 懒惰计算
15.7.1 传名调用计算
15.7.2 按需调用
15.7.3 懒惰程序的计算
15.7.4 懒惰函数式程序的优化
15.7.5 严格性分析
推荐阅读
程序设计:编译函数式语言
习题
第16章 多态类型
16.1 参数多态性
16.1.1 显式带类型的多态语言
16.1.2 多态类型的检查
16.2 类型推论
16.2.1 一个隐式类型的多态语言
16.2.2 类型推论算法
16.2.3 递归的数据类型
16.2.4 Hindley Milner类型的能力
16.3 多态变量的表示
16.3.1 多态函数的扩展
16.3.2 完全的装箱转换
16.3.3 基于强制的表示分析
16.3.4 将类型作为运行时参数传递
16.4 静态重载的解决方法
推荐阅读
习题
第17章 数据流分析
17.1 流分析使用的中间表示
17.2 各种数据流分析
17.2.1 到达定值
17.2.2 可用表达式
17.2.3 到达表达式
17.2.4 活跃分析
17.3 使用数据流分析结果的几种转换
17.3.1 公共子表达式删除
17.3.2 常数传播
17.3.3 复写传播
17.3.4 死代码删除
17.4 加快数据流分析
17.4.1 位向量
17.4.2 基本块
17.4.3 结点排序
17.4.4 使用-定值链和定值-使用链
17.4.5 工作表算法
17.4.6 增量式数据流分析
17.5 别名分析
17.5.1 基于类型的别名分析
17.5.2 基于流的别名分析
17.5.3 使用可能别名信息
17.5.4 严格的纯函数式语言中的别名分析
推荐阅读
习题
第18章 循环优化
18.1 必经结点
18.1.1 寻找必经结点的算法
18.1.2 直接必经结点
18.1.3 循环
18.1.4 循环前置结点
18.2 循环不变量计算
18.3 归纳变量
18.3.1 发现归纳变量
18.3.2 强度削弱
18.3.3 删除
18.3.4 重写比较
18.4 数组边界检查
18.5 循环展开
推荐阅读
习题
第19章 静态单赋值形式
19.1 转化为SSA形式
19.1.1 插入Φ函数的标准
19.1.2 必经结点边界
19.1.3 插入Φ函数
19.1.4 变量重命名
19.1.5 边分割
19.2 必经结点树的高效计算
19.2.1 深度优先生成树
19.2.2 半必经结点
19.2.3 Lengauer Tarjan算法
19.3 使用SSA的优化算法
19.3.1 死代码删除
19.3.2 简单的常数传播
19.3.3 条件常数传播
19.3.4 保持必经结点性质
19.4 数组、指针和存储器
19.5 控制依赖图
19.6 从SSA形式转变回来
19.7 函数式中间形式
推荐阅读
习题
第20章 流水和调度
20.1 没有资源约束时的循环调度
20.2 有资源约束的循环流水
20.2.1 模调度
20.2.2 寻找最小的启动间距
20.2.3 其他控制流
20.2.4 编译器应该调度指令吗
20.3 分支预测
20.3.1 静态分支预测
20.3.2 编译器应该预测分支吗
推荐阅读
习题
第21章 存储层次
21.1 cache的组织结构
21.2 cache块对齐
21.3 预取
21.4 循环交换
21.5 分块
21.6 垃圾收集和存储层次
推荐阅读
习题
附录 Tiger语言参考手册
参考文献
索引

编辑推荐

  《现代编译原理:C语言描述》适用于高等院校计算机及相关专业的本科生或研究生,也可供科研人员或工程技术人员参考。

前言

  本书全面讲述了现代编译器的结构、编译算法和实现方法,是Andrew W.Apple的“虎书”——Modern Compiler Implementation——“红、蓝、绿”三序列之一。这三本书的内容基本相同,但是使用不同的语言来实现书中给出的一个编译器。本书使用的是更适合广大读者的c语言,而另外两本书分别采用ML语言和Java语言。. 国外关于编译技术有三本比较著名的书,分别被誉为“龙书”、“鲸书”和“虎书”。“虎书”即是本书,它已经被国外许多著名大学选作编译原理课程的教材。编译器的设计与实现是一种实践性很强的工程。作为讲述编译器实现方法的编译原理课程,既需要讲述理论和原理,也离不开具体的实践。

内容概要

Andrew W.Appel,美国普林斯顿大学计算机科学系教授,第26届ACM SIGPLAN-SIGACT程序设计原理年会大会执行主席,1998-1999年在贝尔实验室做研究工作。主要研究方向是计算机安全、编译器设计、程序设计语言等。

章节摘录

  近十余年来,编译器的构建方法出现了一些新的变化。一些新的程序设计语言已经得到应用,例如,具有动态方法的面向对象语言、具有嵌套作用域和一阶函数闭包(first-class function closure)的函数式语言等,这些语言中有许多都需要垃圾收集技术的支持。另一方面,新的计算机都有较大的寄存器集合,且存储器访问成为了影响性能的主要因素,这类机器在具有指令调度能力,并能对指令和数据高速缓存(cache)进行局部性优化的编译器辅助下,常常能运行得更快。. 本书可作为一到两个学期编译课程的教材。

图书封面


 现代编译原理-C语言描述下载 更多精彩书评



发布书评

 
 


精彩书评 (总计5条)

  •     谁实现了这个C版本的编译器?有代码吗?分享一下,Java的编译器代码也行.这本书只有头文件*.h.爷爷的.没有具体的实现,郁闷.anyone share the Code will receive a gift.
  •     实在是和实际工作差的远了点,而且理论的东西太多。如果不是真的想研究编译器的话,读读知道个大概也就行了。开始的编译树等知识还能凑和看懂,进入路径优化和寄存器分配就完全是在云里雾里的感觉。优化部分,《深入理解计算机》里讲得更实用。书里最有意思的应该是分别把Tiger语言改为Pure Function或者OO的,仔细读下来,可以很好的理解不同语言的实现含义和运行方式。
  •     http://gc-daniel-0318.spaces.live.com/blog/cns!B6826F6CF83C99E!5031.entry随手写几个,一是推荐几本书,二是交流一下学习体会首先是编程语言,这个东西是最没必要挑书的。刚入门的时候找本简单点的,能马上上手的,最好比较薄——也就是比较便宜——的书看看,比方工具王谭浩强的系列,比方钱能的C++前半本,然后就可以转到手册或者编译器带的帮助之类,各种语言的手册都是免费的。至于所谓的深度讲解、核心编程之类,当资料查查就行了,看不看的意思不大,具体原因稍后解释基本的语言概念有了,就可以看数据结构了。其实讲语言没有不讲数据结构的,像链表、堆栈什么的,所以单纯的数据结构书也不用挑剔,随便什么语言的都无所谓,根据自己需要,找著名出版社出的一线教师写的书,比方清华那本黄皮的C++版,好象是温冬婵等三人写的。数据结构也是为了解决实际问题,所以只要对基本的数据结构有印象就行了,也没必要选怎么怎么牛的书然后就是算法,这个是肯定要下大力气学习的。讲数据结构的书也没有不谈算法的,排序、查找等基本算法在数据结构书里都有。学算法主要的是原理,什么语言都一样。最实惠的是复杂度分析,恰好算法优劣比较是设计算法的大问题,所以这部分是重点又是难点。但是似乎现在能见到的大多数算法书都对复杂度分析讲的很简单,把篇幅集中在具体的算法上,所以只好自己从书里分析每个算法的过程里去体会,上学的时候在图书馆也看到过一些书上对这块讲的很清楚。我读过的大部分算法书都还有一个共同问题,就是让我很不服气。里面列举了大量的经典问题和著名算法,看的我很起劲,但是一把书合起来,脑子里一过,就发现,我要是遇到一问题,能想得出这样的算法吗?实践证明,我还真想不出来,第一反应一般总会是个基本的但也是极笨的算法。我还真就从来没遇到过一本真正教会人设计算法的书。这类书,可遇而不可求了。TAOCP绝对是作为工具书的好材料,当然,读起来也很有意思,DEK确实是个好笔杆子,但对我来说就是关键时刻求助用以上这些方面都是在实际编码过程里可以看得出的招数拳脚,还有一些就属于内功修炼了,一时看不到效果,但是关键时刻可以体现出水平操作系统,这里指的是操作系统原理,而不是操作之类。要是入门的话,推荐stalling的,好象是叫什么概念内核和分析之类的吧,国内有中文版,我读的是灰绿色封面的一版,原版的也有。这本书把基本概念讲解的还算清楚,虽然作者没说,但我感觉是按经典的系统5的路子,而且这本书也是为数不多的讲解管程的一本教材。还有就是关于MINIX、XENIX之类结合代码讲解的。之后可以看的书就多了,什么分布式、高级OS等,要想深刻学习,可以读代码,比方莱昂氏代码分析和LINUX代码分析,这两本看完,OS问题基本上就全部解决了,读这些代码的时候还可以学习编程技巧。OS编程是最简单的编程,它完全是在硬件能力基础上建立,自己定义规则而不需要遵循别的规则,但同时OS编程也是最复杂的,因为涉及的数据结构和算法种类多,要考虑的问题也多。UNIX和LINUX用的人那么多,一旦有人执行特殊操作,后果不堪设想,所以WINDOWS不断有UPDATE包出现。读这些代码其实也很有意思。不过我只是上学的时候读了莱昂氏的文件管理,刚毕业的时候读了一点LINUX的I/O控制两部分,读的也不全,而且忘的很快编译原理,别以为这个只有做编译器的人才需要读,其实读好这门课,再思考代码的时候会有高屋建瓴的感觉。读编译原理之后,很明显的一个变化就是对代码的理解完全不一样了,对于代码应该怎么写,为什么要那么写,怎么写更好,错误是如何出现的,如果出错的后果,都能有理论到实践的全面认识,而那些深度讲解、核心编程之类的书之所以可以不看,也是因为在有了OS概念和编译理论后,这些东西稍微一想就能明白,原理都是一样的。那些深度讲解、核心编程之类的书都是给非计算机专业的人看的,因为他们不熟悉OS原理和编译理论等基础,无法一下子建立起比如进程线程控制、内存管理等概念,所以这些书手把手的教他们写代码,而且也是只教方法不讲原理。编译书,入门的可以看张幸儿教授的那本,讲解的蛮清楚的,自学就能懂。我在学校的教材就是这本,基本上也是自学的。这本书最大的问题在于,稍微老了点,所以代码优化部分不看也罢,词法语法分析部分也只讲到LR1的难度。之后,可以去看著名的“龙书”,好象是叫做什么编译原理概念原理与实践,封面有一条红色的大龙。这本书在编译领域20多年不衰,可见其地位。这本书对理论讲的很明白,但是问题也在于,老了点。不过因为LRK到现在一直都还没被淘汰,而且对于内存部分讲的很实用。这个我也只读到了词法语法分析就没再继续下去。这本书国内有影印,但是很难买。还有一本“虎书”,封面是绿色,有一只老虎,这本书出版时间比较晚,内容还挺新,每部分还都有实践,学完后把代码拼起来基本上就是个编译器。这本书国内有卖的,公司bookshell上也放过,我上学的时候也读过,当时是为了应付考试,后来发现考试没那么难,所以没读完这些基本功相关的书都过一遍,但不用看的很详细,所谓好读书不求甚解,然后就可以结合必要的数学、应用知识,深入各个领域了有人提到离散数学方面,这是对计算机领域最有用的一个数学分支。那本ROSEN教授的书,最好买最新版,这个老家伙很坏,每次更新版本都有很多变化。不过这种基础理论课没必要看洋人的,理论基础研究中国一直没落后过。北大耿素云、屈婉玲等人的那本就不错,清华一个张XX写的也挺好。只是北大那本书里有个别错误和疏漏,不知道现在最新版的纠正了没有。如果想要学的深刻点,可以看东南大学朱一清教授的,这个也是上学的时候老师推荐我们看的。朱教授的书写的深浅搭配很好,她的课也有意思。我上学的时候专门跑到东南去听过几次,不但在知识上,而且从讲课方式到语言风格都受益非浅。她的书也秉承了这个作风,内容严谨清晰。尤其关于数理逻辑部分,可能是因为她和我的老师是一脉相承,所以我对她的理论体系更容易接受,都是希尔伯特的理论体系,不是甘岑的体系

精彩短评 (总计50条)

  •     这是我们老师推荐的,看完之后感觉很抽象,跟其他翻译过来的教材一样,没有主线的感觉
  •     牛!!!
  •     还不错就是有些细节不怎么了解
  •     书的质量还不错,书的内容大家都知道,没话说
  •     书中省略没提很多基础的东西,一看书的架势就是把读者定位到高点,虽然是本科教材,但是我还是觉得,这个开始就适合研究生用吧,个人之见
  •     和龙书一样都值得深读
  •     书很好,只是自学起来难度大了些。
  •     教材。读了前半本。
  •     看得可以很快。。
  •     不错就是速度太慢了
  •     一本专业性很强的书,值得学习。
  •     教材。。
  •     代码看的我火大。讲解太不清楚了。
  •     不错,很高深
  •     书内部的封皮烂了一页
  •     好书,以一种比较简单的方式讲编译器的构造。跟另外两本相比,是最薄的了。
  •     看了一点,先放着先吧,有空再看
  •     内容不错啊,就是有点难度,一定要有离散数学的基础
  •     还不懂
  •     书本身内容不错,这这一系列的经典书籍,我们是当作教材来用的。
  •     感觉很有用,就是内容太难了
  •     源代码少了点.
  •     读过一部分,其中的精髓还有待领悟...
  •     书是不错,印刷的质量很好~结果老师就讲了四章,唉……
  •     |大三,编译 难度大
  •     虎书,大概看了一遍,由于自己太菜了,除了对编译原理的流程有个大概了解,别的都不太懂。
  •     其实已经读了好久了,只是一直都没有读完。
  •     >.<
  •     就喜欢短小精悍的书
  •     最后还是自己手写了一个LR(1)...好痛苦。。不过翻译的时候更痛苦。。
  •     感觉排版的不太好,字体也太小了,感觉没有层次感!!!所以到现在这本书还没有看完。。。。
  •     虎书中文版
  •     去年写编译原理大作业时读了前段部分,偏实践的书~很受用!!
  •     这本书相当不错,是编译原理三剑客中内容相对最新的了吧,并且很全面
  •     和龙书一样糟糕,关键纯理论学习还比不上龙书。拿这本来实践,真心是噩梦。
  •     书的结构不错,比较详细
  •     翻过一篇
  •     实现一个简单的C编译器。过多强调函数编程,实现的语言语法比较“诡异”。
  •     很久以前看过,只怪自己头壳愚钝,看了等于没看
  •     很好很强大啊
  •     建议有经验的开发人员看,初学者就不要看了,还是有很大的难度的哈
  •     好书,好书,可惜就是太难懂了,不适合初学者
  •     2013-09-11 虎书。编译原理课设。对实践指导性强,只看了前几个章节。
  •     这是龙虎鲸三本书中的,第二本虎书,研究编译器必看!
  •     现在还看不怎么懂的不过以后我的水平高了相信应该可以给我很大的好处的哦
  •     好东西!!
  •     非常实用,里面各种算法对我帮助很大。在我写的一个LALR语法分析生成器中,用了好几个这本书中介绍的算法,如果想了解细节可以看龙书,如果要实践那毫无置疑的要选择虎书。
  •     看到第一章结束,让我们看程序1-5,找了10分钟没找到,看来是忘了编号。找来影印本看了下,是有编号的。果断放弃这边中文版,改看影印本吧...
  •     这是虎书,强烈推荐!如果你已经从编译原理龙书入门,那么再看此书犹如如虎添翼
  •     想买一本中文的,发现居然没得卖了???
 

农业基础科学,时尚,美术/书法,绘画,软件工程/开发项目管理,研究生/本专科,爱情/情感,动漫学堂PDF下载,。 PDF下载网 

PDF下载网 @ 2024