-
内容大纲
本书是在教育部计算机领域本科教育教学改革试点工作计划“编译原理”课程组的组织下编写的理论教材之一。本书从理论和实践两个方面指导与帮助学生深刻理解编译器的工作原理。其中,理论方法的教学使得学生能够理解编译器运行过程中的核心算法,而实践技术则帮助学生掌握理论方法及算法在代码实现层面的设计与编码要点,最后结合实践内容对理论方法与实践技术进行巩固。
本书适合作为高校计算机及相关专业编译原理课程的教材,也适合作为研发人员了解编译技术的参考书。 -
作者介绍
-
目录
出版说明
前言
第1章 概述
1.1 内容组织
1.2 编译器的结构
1.2.1 词法分析
1.2.2 语法分析
1.2.3 语义分析
1.2.4 中间代码生成
1.2.5 目标代码生成
1.2.6 中间代码优化
1.3 语言和工具简介
1.3.1 源语言C--简介
1.3.2 目标语言MIPS简介
1.3.3 MIPS模拟器简介
1.3.4 实践环境
第2章 词法分析和语法分析
2.1 词法分析和语法分析的理论方法
2.1.1 词法分析概要
2.1.2 正则表达式
2.1.3 有限状态自动机
2.1.4 从NFA到DFA的转换
2.1.5 状态最小化算法
2.1.6 语法分析概要
2.1.7 上下文无关文法
2.1.8 自顶向下的语法分析算法
2.1.9 自底向上的语法分析算法
2.2 词法分析和语法分析的实践技术
2.2.1 词法分析实现思想概述
2.2.2 GNU Flex介绍
2.2.3 Flex:编写源代码
2.2.4 Flex:书写正则表达式
2.2.5 Flex:高级特性
2.2.6 词法分析实践的额外提示
2.2.7 语法分析实现思想概述
2.2.8 GUN Bison介绍
2.2.9 Bison:编写源代码
2.2.10 Bison:属性值的类型
2.2.11 Bison:词法单元的位置
2.2.12 Bison:二义性与冲突处理
2.2.13 Bison:源代码的调试
2.2.14 Bison:错误恢复
2.2.15 语法分析实践的额外提示
2.3 词法分析和语法分析的实践内容
2.3.1 实践要求
2.3.2 输入格式
2.3.3 输出格式
2.3.4 验证环境
2.3.5 提交要求
2.3.6 样例(必做部分)
2.3.7 样例(选做部分)
2.4 本章小结
习题
第3章 语义分析
3.1 语义分析的理论方法
3.1.1 属性文法
3.1.2 基于属性文法的处理方式
3.1.3 S属性文法和L属性文法
3.1.4 语法制导的定义
3.1.5 语法制导的翻译方案
3.1.6 SDT中左递归的消除
3.1.7 类型检查
3.2 语义分析的实践技术
3.2.1 语义分析实现思想概述
3.2.2 符号表的设计与实现
3.2.3 支持多层作用域的符号表
3.2.4 类型表示
3.2.5 语义分析实践的额外提示
3.3 语义分析的实践内容
3.3.1 实践要求
3.3.2 输入格式
3.3.3 输出格式
3.3.4 验证环境
3.3.5 提交要求
3.3.6 样例(必做部分)
3.3.7 样例(选做部分)
3.4 本章小结
习题
第4章 中间代码生成
4.1 中间代码生成的理论方法
4.1.1 运行时环境概要
4.1.2 存储组织与栈帧设计方法
4.1.3 中间表示
4.1.4 类型与声明
4.1.5 表达式的翻译
4.1.6 控制流与回填
4.2 中间代码生成的实践技术
4.2.1 线形中间表示
4.2.2 图形中间表示
4.2.3 运行时环境简介
4.2.4 基本表达式的翻译模式
4.2.5 语句的翻译模式
4.2.6 函数调用的翻译模式
4.2.7 数组和结构体的翻译模式
4.3 中间代码生成的实践内容
4.3.1 实践要求
4.3.2 输入格式
4.3.3 输出格式
4.3.4 验证环境
4.3.5 提交要求
4.3.6 样例(必做部分)
4.3.7 样例(选做部分)
4.4 本章小结
习题
第5章 目标代码生成
5.1 目标代码生成的理论方法
5.1.1 代码生成概述
5.1.2 指令集架构
5.1.3 基本块与流图
5.1.4 指令选择算法
5.1.5 寄存器分配算法
5.1.6 窥孔优化
5.1.7 代码生成器构建
5.2 目标代码生成的实践技术
5.2.1 QtSpim简介
5.2.2 MIPS32汇编代码简介
5.2.3 指令选择算法实现
5.2.4 朴素寄存器分配算法实现
5.2.5 局部寄存器分配算法实现
5.2.6 活跃变量分析算法实现
5.2.7 图染色算法实现
5.2.8 MIPS寄存器的使用
5.2.9 MIPS栈管理
5.2.10 目标代码生成实践的额外提示
5.3 目标代码生成的实践内容
5.3.1 实践要求
5.3.2 输入格式
5.3.3 输出格式
5.3.4 验证环境
5.3.5 提交要求
5.3.6 样例(必做部分)
5.4 本章小结
习题
第6章 中间代码优化
6.1 中间代码优化的理论方法
6.1.1 中间代码优化概述
6.1.2 数据流分析理论与框架
6.1.3 到达定值分析
6.1.4 可用表达式分析
6.1.5 活跃变量分析
6.2 中间代码优化的实践技术
6.2.1 局部优化
6.2.2 全局优化
6.2.3 过程间优化
6.3 中间代码优化的实践内容
6.3.1 实践要求
6.3.2 输入格式
6.3.3 输出格式
6.3.4 验证环境
6.3.5 提交要求
6.3.6 样例(必做部分)
6.3.7 样例(选做部分)
6.4 本章小结
习题
第7章 结束语
附录
附录A C--语言文法
附录B 虚拟机小程序使用说明
附录C 资源下载和安装说明
参考文献
同类热销排行榜
- C语言与程序设计教程(高等学校计算机类十二五规划教材)16
- 电机与拖动基础(教育部高等学校自动化专业教学指导分委员会规划工程应用型自动化专业系列教材)13.48
- 传感器与检测技术(第2版高职高专电子信息类系列教材)13.6
- ASP.NET项目开发实战(高职高专计算机项目任务驱动模式教材)15.2
- Access数据库实用教程(第2版十二五职业教育国家规划教材)14.72
- 信号与系统(第3版下普通高等教育九五国家级重点教材)15.08
- 电气控制与PLC(普通高等教育十二五电气信息类规划教材)17.2
- 数字电子技术基础(第2版)17.36
- VB程序设计及应用(第3版十二五职业教育国家规划教材)14.32
- Java Web从入门到精通(附光盘)/软件开发视频大讲堂27.92
推荐书目
-
孩子你慢慢来/人生三书 华人世界率性犀利的一枝笔,龙应台独家授权《孩子你慢慢来》20周年经典新版。她的《...
-
时间简史(插图版) 相对论、黑洞、弯曲空间……这些词给我们的感觉是艰深、晦涩、难以理解而且与我们的...
-
本质(精) 改革开放40年,恰如一部四部曲的年代大戏。技术突变、产品迭代、产业升级、资本对接...