作者:
[美]Andrew W.Appel
/
[美]MaiaGinsburg
出版社: 人民邮电出版社
出品方: 图灵教育
副标题: C语言描述(修订版)
译者: 赵克佳 / 黄春 / 沈志宇
出版年: 2018-4
页数: 400
定价: 89.00元
装帧: 平装
丛书: 图灵计算机科学丛书
ISBN: 9787115476883
出版社: 人民邮电出版社
出品方: 图灵教育
副标题: C语言描述(修订版)
译者: 赵克佳 / 黄春 / 沈志宇
出版年: 2018-4
页数: 400
定价: 89.00元
装帧: 平装
丛书: 图灵计算机科学丛书
ISBN: 9787115476883
内容简介 · · · · · ·
本书全面讲述了现代编译器的各个组成部分,包括词法分析、语法分析、抽象语法、语义检查、中间代码表示、指令选择、数据流分析、寄存器分配以及运行时系统等。全书分成两部分,第一部分是编译的基础知识,适用于第一门编译原理课程(一个学期);第二部分是高级主题,包括面向对象语言和函数语言、垃圾收集、循环优化、存储结构优化等,适合于后续课程或研究生教学。
作者简介 · · · · · ·
Andrew W. Appel
美国普林斯顿大学计算机科学系教授,第26届ACM SIGPLAN-SIGACT程序设计原理年会大会执行主席,1998~1999年在贝尔实验室做研究工作。主要研究方向是计算机安全、编译器设计、程序设计语言等。
Maia Ginsburg
美国普林斯顿大学计算机科学系讲师。
目录 · · · · · ·
第一部分 编译基本原理
第1章 绪论 1
1.1 模块与接口 1
1.2 工具和软件 3
1.3 树语言的数据结构 3
程序设计:直线式程序解释器 7
推荐阅读 8
习题 9
第2章 词法分析 10
2.1 词法单词 10
2.2 正则表达式 11
2.3 有限自动机 13
2.4 非确定有限自动机 15
2.5 Lex:词法分析器的生成器 20
程序设计:词法分析 22
推荐阅读 23
习题 23
第3章 语法分析 27
3.1 上下文无关文法 28
3.2 预测分析 32
3.3 LR分析 39
3.4 使用分析器的生成器 48
3.5 错误恢复 54
程序设计:语法分析 57
推荐阅读 58
习题 58
第4章 抽象语法 62
4.1 语义动作 62
4.2 抽象语法分析树 65
程序设计:抽象语法 71
推荐阅读 71
习题 72
第5章 语义分析 73
5.1 符号表 73
5.2 Tiger编译器的绑定 79
5.3 表达式的类型检查 82
5.4 声明的类型检查 84
程序设计:类型检查 86
习题 87
第6章 活动记录 89
6.1 栈帧 90
6.2 Tiger编译器的栈帧 96
程序设计:栈帧 102
推荐阅读 103
习题 103
第7章 翻译成中间代码 106
7.1 中间表示树 106
7.2 翻译为树中间语言 108
7.3 声明 120
程序设计:翻译成树 122
习题 123
第8章 基本块和轨迹 125
8.1 规范树 126
8.2 处理条件分支 131
推荐阅读 134
习题 134
第9章 指令选择 136
9.1 指令选择算法 138
9.2 CISC机器 144
9.3 Tiger编译器的指令选择 146
程序设计:指令选择 152
推荐阅读 153
习题 154
第10章 活跃分析 155
10.1 数据流方程的解 156
10.2 Tiger编译器的活跃分析 162
程序设计:构造流图 164
程序设计:活跃分析模块 165
习题 165
第11章 寄存器分配 166
11.1 通过简化进行着色 166
11.2 合并 168
11.3 预着色的结点 171
11.4 图着色的实现 175
11.5 针对树的寄存器分配 181
程序设计:图着色 184
推荐阅读 185
习题 185
第12章 整合为一体 188
程序设计:过程入口/出口 189
程序设计:创建一个可运行的编译器 191
第二部分 高级主题
第13章 垃圾收集 193
13.1 标记-清扫式收集 194
13.2 引用计数 197
13.3 复制式收集 198
13.4 分代收集 201
13.5 增量式收集 203
13.6 Baker算法 205
13.7 编译器接口 205
程序设计:描述字 208
程序设计:垃圾收集 208
推荐阅读 208
习题 210
第14章 面向对象的语言 211
14.1 类 211
14.2 数据域的单继承性 213
14.3 多继承 214
14.4 测试类成员关系 216
14.5 私有域和私有方法 218
14.6 无类语言 219
14.7 面向对象程序的优化 219
程序设计:OBJECT-Tiger 220
推荐阅读 220
习题 221
第15章 函数式程序设计语言 222
15.1 一个简单的函数式语言 222
15.2 闭包 224
15.3 不变的变量 225
15.4 内联扩展 229
15.5 闭包变换 233
15.6 高效的尾递归 235
15.7 懒惰计算 236
推荐阅读 243
程序设计:编译函数式语言 244
习题 244
第16章 多态类型 246
16.1 参数多态性 246
16.2 类型推论 253
16.3 多态变量的表示 259
16.4 静态重载的解决方法 265
推荐阅读 266
习题 266
第17章 数据流分析 269
17.1 流分析使用的中间表示 270
17.2 各种数据流分析 271
17.3 使用数据流分析结果的几种转换 274
17.4 加快数据流分析 276
17.5 别名分析 281
推荐阅读 285
习题 285
第18章 循环优化 287
18.1 必经结点 289
18.2 循环不变量计算 292
18.3 归纳变量 293
18.4 数组边界检查 297
18.5 循环展开 300
推荐阅读 301
习题 301
第19章 静态单赋值形式 303
19.1 转化为SSA形式 305
19.2 必经结点树的高效计算 310
19.3 使用SSA的优化算法 315
19.4 数组、指针和存储器 320
19.5 控制依赖图 321
19.6 从SSA形式转变回来 323
19.7 函数式中间形式 324
推荐阅读 327
习题 328
第20章 流水和调度 331
20.1 没有资源约束时的循环调度 332
20.2 有资源约束的循环流水 336
20.3 分支预测 341
推荐阅读 343
习题 343
第21章 存储层次 346
21.1 cache的组织结构 346
21.2 cache块对齐 349
21.3 预取 350
21.4 循环交换 354
21.5 分块 355
21.6 垃圾收集和存储层次 357
推荐阅读 358
习题 358
附录 Tiger语言参考手册 360
参考文献 368
索引 376
· · · · · · (收起)
第1章 绪论 1
1.1 模块与接口 1
1.2 工具和软件 3
1.3 树语言的数据结构 3
程序设计:直线式程序解释器 7
推荐阅读 8
习题 9
第2章 词法分析 10
2.1 词法单词 10
2.2 正则表达式 11
2.3 有限自动机 13
2.4 非确定有限自动机 15
2.5 Lex:词法分析器的生成器 20
程序设计:词法分析 22
推荐阅读 23
习题 23
第3章 语法分析 27
3.1 上下文无关文法 28
3.2 预测分析 32
3.3 LR分析 39
3.4 使用分析器的生成器 48
3.5 错误恢复 54
程序设计:语法分析 57
推荐阅读 58
习题 58
第4章 抽象语法 62
4.1 语义动作 62
4.2 抽象语法分析树 65
程序设计:抽象语法 71
推荐阅读 71
习题 72
第5章 语义分析 73
5.1 符号表 73
5.2 Tiger编译器的绑定 79
5.3 表达式的类型检查 82
5.4 声明的类型检查 84
程序设计:类型检查 86
习题 87
第6章 活动记录 89
6.1 栈帧 90
6.2 Tiger编译器的栈帧 96
程序设计:栈帧 102
推荐阅读 103
习题 103
第7章 翻译成中间代码 106
7.1 中间表示树 106
7.2 翻译为树中间语言 108
7.3 声明 120
程序设计:翻译成树 122
习题 123
第8章 基本块和轨迹 125
8.1 规范树 126
8.2 处理条件分支 131
推荐阅读 134
习题 134
第9章 指令选择 136
9.1 指令选择算法 138
9.2 CISC机器 144
9.3 Tiger编译器的指令选择 146
程序设计:指令选择 152
推荐阅读 153
习题 154
第10章 活跃分析 155
10.1 数据流方程的解 156
10.2 Tiger编译器的活跃分析 162
程序设计:构造流图 164
程序设计:活跃分析模块 165
习题 165
第11章 寄存器分配 166
11.1 通过简化进行着色 166
11.2 合并 168
11.3 预着色的结点 171
11.4 图着色的实现 175
11.5 针对树的寄存器分配 181
程序设计:图着色 184
推荐阅读 185
习题 185
第12章 整合为一体 188
程序设计:过程入口/出口 189
程序设计:创建一个可运行的编译器 191
第二部分 高级主题
第13章 垃圾收集 193
13.1 标记-清扫式收集 194
13.2 引用计数 197
13.3 复制式收集 198
13.4 分代收集 201
13.5 增量式收集 203
13.6 Baker算法 205
13.7 编译器接口 205
程序设计:描述字 208
程序设计:垃圾收集 208
推荐阅读 208
习题 210
第14章 面向对象的语言 211
14.1 类 211
14.2 数据域的单继承性 213
14.3 多继承 214
14.4 测试类成员关系 216
14.5 私有域和私有方法 218
14.6 无类语言 219
14.7 面向对象程序的优化 219
程序设计:OBJECT-Tiger 220
推荐阅读 220
习题 221
第15章 函数式程序设计语言 222
15.1 一个简单的函数式语言 222
15.2 闭包 224
15.3 不变的变量 225
15.4 内联扩展 229
15.5 闭包变换 233
15.6 高效的尾递归 235
15.7 懒惰计算 236
推荐阅读 243
程序设计:编译函数式语言 244
习题 244
第16章 多态类型 246
16.1 参数多态性 246
16.2 类型推论 253
16.3 多态变量的表示 259
16.4 静态重载的解决方法 265
推荐阅读 266
习题 266
第17章 数据流分析 269
17.1 流分析使用的中间表示 270
17.2 各种数据流分析 271
17.3 使用数据流分析结果的几种转换 274
17.4 加快数据流分析 276
17.5 别名分析 281
推荐阅读 285
习题 285
第18章 循环优化 287
18.1 必经结点 289
18.2 循环不变量计算 292
18.3 归纳变量 293
18.4 数组边界检查 297
18.5 循环展开 300
推荐阅读 301
习题 301
第19章 静态单赋值形式 303
19.1 转化为SSA形式 305
19.2 必经结点树的高效计算 310
19.3 使用SSA的优化算法 315
19.4 数组、指针和存储器 320
19.5 控制依赖图 321
19.6 从SSA形式转变回来 323
19.7 函数式中间形式 324
推荐阅读 327
习题 328
第20章 流水和调度 331
20.1 没有资源约束时的循环调度 332
20.2 有资源约束的循环流水 336
20.3 分支预测 341
推荐阅读 343
习题 343
第21章 存储层次 346
21.1 cache的组织结构 346
21.2 cache块对齐 349
21.3 预取 350
21.4 循环交换 354
21.5 分块 355
21.6 垃圾收集和存储层次 357
推荐阅读 358
习题 358
附录 Tiger语言参考手册 360
参考文献 368
索引 376
· · · · · · (收起)
"现代编译原理"试读 · · · · · ·
本书全面讲述了现代编译器的结构、编译算法和实现方法,是Andrew W.Apple的“虎书”———ModernCompilerImplementation——— “红、蓝、绿”三序列之一。这三本书的内容基本相同,但是使用不同的语言来实现书中给出的一个编译器。本书使用的是更适合广大读者的C 语言,而另外两本书分别采用ML 和Java语言。 国外关于编译技术有三本比较著名的书,分别被誉为“龙书”“鲸书”和“虎书”。...
· · · · · · (查看全部试读)
原文摘录 · · · · · ·
-
Two of the most useful abstractions used in modern compilers are context-free grammars, for parsing, and regular expressions, for lexical analysis. To make best use of these abstractions it is helpful to have special tools, such as Yacc (which converts a grammar into a parsing program)and Lex(which converts a declarative specification into a lexical analysis program). (查看原文) —— 引自第5页
丛书信息
· · · · · ·
图灵计算机科学丛书(共63册),
这套丛书还有
《UML面向对象建模与设计》《UNIX网络编程 卷1:套接字联网API(第3版)》《计算机图形学》《TCP/IP指南(卷2)》《计算机体系结构》
等
。
喜欢读"现代编译原理"的人也喜欢 · · · · · ·
-
- 编译器设计 8.4
-
- 自制编译器 8.2
-
- Lua设计与实现 8.2
-
- 魔力Haskell 8.3
-
- C语言接口与实现 8.3
-
- Python网络编程(第3版) 9.1
-
- 用Go语言自制解释器 9.6
-
- 计算机体系结构 9.5
现代编译原理的书评 · · · · · · ( 全部 11 条 )


不如龙书全但胜在友好
比龙书要好入门,不是天才的话直接看龙书还是压力有点大,且龙书机械工业出版社的翻译版不太友好。 虎书内容要少得多,但是麻雀虽小五脏俱全,学习曲线平滑,适合本科生自学。 本书配合斯坦福的公开课,可以说是入门编译理论目前最佳教材了。想深入,可以再去查龙书,个人建议...
(展开)


> 更多书评 11篇
论坛 · · · · · ·
在这本书的论坛里发言这本书的其他版本 · · · · · · ( 全部8 )
-
人民邮电出版社 (2006)8.4分 161人读过
-
Cambridge University Press (2004)8.0分 25人读过
-
人民邮电出版社 (2005)8.3分 33人读过
-
以下书单推荐 · · · · · · ( 全部 )
- IT 二级基础 编译原理(编译、解释、虚拟机)(智力层次-实用性) 1.1.1.8 (ajian005)
- 评分9分以上的计算机图书 (子苓)
- 待购书籍 (欧阳杼)
- CS推荐 (橄榄树萍)
- T (dhcn)
谁读这本书? · · · · · ·
二手市场
· · · · · ·
订阅关于现代编译原理的评论:
feed: rss 2.0
23 有用 迷路的太空人 2019-12-13 14:34:02
好难啊啊啊啊啊啊啊啊,写得略不平易近人。 推荐大家去看哈工大老师的视频教学,然后回来感谢我吧☺
0 有用 QL-Cu1 2022-06-23 00:50:31
龙书屁话太多,还是虎书比较精炼。
0 有用 瑜彦伯璋 2021-09-13 13:12:22
这个必须有基础才能读,否则看不懂
3 有用 litanyue 2019-11-18 19:45:31
能把计算机类书籍讲的不在天上在地上,大家都知道,这是一件相当难的事情,这本书做到了。
1 有用 𝕾𝖚𝖓 2019-10-30 22:01:11
《编译原理》课的教材,用 C 语言(本书另有 Java 和 SML 版本)从头实现了一个 TIGER 语言到 RISC 指令集的编译器,之后还简单讲了 GC / OOP / FP 等高级话题。