王朝网络
分享
 
 
 

现代编译原理:C语言描述(图灵计算机科学丛书)

王朝导购·作者佚名
 
现代编译原理:C语言描述(图灵计算机科学丛书)  点此进入淘宝搜索页搜索
  特别声明:本站仅为商品信息简介,并不出售商品,您可点击文中链接进入淘宝网搜索页搜索该商品,有任何问题请与具体淘宝商家联系。
  参考价格: 点此进入淘宝搜索页搜索
  分类: 图书,计算机与互联网,程序语言与软件开发,编译原理和编译器,
  品牌: 安佩尔

基本信息·出版社:人民邮电出版社

·页码:385 页

·出版日期:2006年

·ISBN:7115145520

·条形码:9787115145529

·包装版本:2006-04-01

·装帧:平装

·开本:16开

·丛书名:图灵计算机科学丛书

产品信息有问题吗?请帮我们更新产品信息。

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

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

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

编辑推荐《现代编译原理: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用elTOI‘符号恢复

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函数定义

程序设计:翻译成树

习题

第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 CIS(:机器

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面向对象程序的优化

程序设计:OBJE~~:T—Tigei’

推荐阅读

习题

第15章 函数式程序设计语言

15.1一个简单的函数式语言

15.2闭包

15.3不变的变量

15.3.1基于延续的L/O

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 HindleyMilner类型的能力

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 LengauerTarjan算法

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语言参考手册

参考文献

索引~

……[看更多目录]

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

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

 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
更多商品
有效的时间管理(组织潜能提升系列)
从营销计划到销量倍增(原书第2版)(阿呆系列)
边际谋杀:奇案中的经济学
从历史看组织
波斯人信札
集合论基础(英文版)/图灵原版数学统计学系列
人力资源管理师(职业技术·职业资格培训教材)
化妆造型(职业技能培训教材)
彩版儿童折纸全书(精装)
彩版儿童剪纸大全(精装)
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有