编译原理教程 第3版PDF电子书下载
- 电子书积分:10 积分如何计算积分?
- 作 者:胡元义著
- 出 版 社:西安:西安电子科技大学出版社
- 出版年份:2010
- ISBN:9787560624631
- 页数:235 页
第一章 绪论 1
1.1 程序设计语言和编译程序 1
1.2 编译程序的历史及发展 3
1.3 编译过程和编译程序结构 4
1.4 编译程序的开发 5
1.5 构造编译程序所应具备的知识内容 6
习题一 8
第二章 词法分析 9
2.1 词法分析器的设计方法 9
2.1.1 单词符号的分类与输出形式 9
2.1.2 状态转换图 10
2.2 一个简单的词法分析器示例 12
2.2.1 C语言子集的单词符号表示 12
2.2.2 C语言子集对应的状态转换图 12
2.2.3 状态转换图的实现 13
2.3 正规表达式与有限自动机简介 16
2.3.1 正规表达式与正规集 16
2.3.2 有限自动机 17
2.4 正规表达式到有限自动机的构造 20
2.4.1 由正规表达式构造等价的非确定有限自动机(NEA) 20
2.4.2 NFA的确定化 21
2.4.3 确定有限自动机(DFA)的化简 22
2.4.4 正规表达式到有限自动机构造示例 24
2.5 词法分析器的自动生成 28
习题二 30
第三章 语法分析 33
3.1 文法和语言 33
3.1.1 文法和语言的基本概念 33
3.1.2 形式语言分类 36
3.1.3 正规表达式与上下文无关文法 38
3.2 推导与语法树 39
3.2.1 推导与短语 39
3.2.2 语法树与二义性 40
3.3 自顶向下的语法分析 44
3.3.1 递归下降分析法 44
3.3.2 LL(1)分析法 52
3.4 自底向上的语法分析 58
3.4.1 自底向上分析原理 58
3.4.2 算符优先分析法 60
3.5 规范归约的自底向上语法分析方法 70
3.5.1 LR分析器的工作原理 70
3.5.2 LR(0)分析器 73
3.5.3 SLR(1)分析器 78
3.5.4 LR(1)分析器 81
3.5.5 LALR分析器 86
3.5.6 二义文法的应用 88
3.5.7 LR分析器应用与拓展 92
习题三 93
第四章 语义分析和中间代码生成 101
4.1 概述 101
4.1.1 语义分析的概念 101
4.1.2 语法制导翻译方法 101
4.2 属性文法 103
4.2.1 文法的属性 103
4.2.2 属性文法 103
4.3 几种常见的中间语言 105
4.3.1 抽象语法树 105
4.3.2 逆波兰表示法 105
4.3.3 三地址代码 107
4.4 表达式及赋值语句的翻译 110
4.4.1 简单算术表达式和赋值语句的翻译 110
4.4.2 布尔表达式的翻译 111
4.5 控制语句的翻译 116
4.5.1 条件语句if的翻译 116
4.5.2 条件循环语句while的翻译 118
4.5.3 三种基本控制结构的翻译 119
4.5.4 多分支控制语句case的翻译 124
4.5.5 语句标号和转移语句的翻译 126
4.6 数组元素的翻译 126
4.6.1 数组元素的地址计算及中间代码形式 127
4.6.2 赋值语句中数组元素的翻译 127
4.6.3 数组元素翻译示例 128
4.7 过程或函数调用语句的翻译 131
4.7.1 过程或函数调用的方法 131
4.7.2 过程或函数调用语句的四元式生成 132
4.8 说明语句的翻译 133
4.8.1 变量说明的翻译 133
4.8.2 数组说明的翻译 134
4.9 递归下降语法制导翻译方法简介 134
习题四 136
第五章 代码优化 139
5.1 局部优化 139
5.1.1 基本块的划分方法 139
5.1.2 基本块的DAG方法 140
5.1.3 用DAG进行基本块的优化处理 144
5.1.4 DAG构造算法的进一步讨论 145
5.2 循环优化 146
5.2.1 程序流图与循环 146
5.2.2 循环的查找 148
5.2.3 循环优化 152
5.3 全局优化概述 160
5.3.1 到达-定值与引用-定值链 160
5.3.2 定值-引用链(du链) 164
5.3.3 写传播 167
5.4 代码优化示例 170
习题五 173
第六章 目标程序运行时存储空间的组织 177
6.1 静态存储分配 177
6.2 简单的栈式存储分配 178
6.2.1 栈式存储分配与活动记录 179
6.2.2 过程的执行 181
6.3 嵌套过程语言的栈式实现 183
6.3.1 嵌套层次显示(DISPLAY)表和活动记录 183
6.3.2 嵌套过程的执行 184
6.3.3 访问非局部名的另一种实现方法 185
6.4 堆式动态存储分配 189
6.4.1 堆式存储的概念 189
6.4.2 堆式存储的管理方法 189
6.5 参数传递补遗 191
6.5.1 参数传递的方法 191
6.5.2 不同参数传递方法比较 192
习题六 194
第七章 目标代码生成 196
7.1 简单代码生成器 196
7.1.1 待用信息与活跃信息 197
7.1.2 代码生成算法 199
7.1.3 寄存器分配 200
7.1.4 源程序到目标代码生成示例 202
7.2 汇编指令到机器代码翻译概述 204
习题七 210
第八章 符号表与错误处理 212
8.1 符号表 212
8.1.1 符号表的作用 212
8.1.2 符号表的组织 213
8.1.3 分程序结构语言符号表建立 214
8.1.4 非分程序结构语言符号表建立 217
8.1.5 常用符号表结构 218
8.1.6 符号表内容 219
8.2 错误处理 219
8.2.1 语法错误校正 220
8.2.2 语义错误校正 226
习题八 227
附录1 8086/8088指令码汇总表 229
附录2 8086/8088指令编码空间表 234
参考文献 236
- 《高级英语阅读与听说教程》刘秀梅编著 2019
- 《看图自学吉他弹唱教程》陈飞编著 2019
- 《激光加工实训技能指导理实一体化教程 下》王秀军,徐永红主编;刘波,刘克生副主编 2017
- 《AutoCAD 2019 循序渐进教程》雷焕平,吴昌松,陈兴奎主编 2019
- 《少儿电子琴入门教程 双色图解版》灌木文化 2019
- 《Photoshop CC 2018基础教程》温培利,付华编著 2019
- 《剑桥国际英语写作教程 段落写作》(美)吉尔·辛格尔顿(Jill Shingleton)编著 2019
- 《英语自学进阶教程全6册 3》爱尔兰迪尔德丽出版社著 2019
- 《雅马哈管乐队训练教程 降E调单簧管 分谱》Japan Band Clinic委员会 2019
- 《线性代数简明教程》刘国庆,赵剑,石玮编著 2019