自己动手构造编译系统

自己动手构造编译系统

编译、汇编与链接

暂无评价综合评分的显示会考虑用户真实性等多项因素,每部作品出现综合评分的时间不定。
7.223 评价豆瓣读书
阅读浸润 岁月留香满500减300、满200减120、满100减60活动详情

作品简介

本书以作者实现的一个基于Intelx86指令集的编译系统为例,结合程序代码的主要部分详细阐述了编译系统的实现原理和过程。

本书对编译器、汇编器、链接器、编译优化器涉及的关键算法、数据结构和程序实现流程,以及ELF文件的格式、Intel指令格式均作了详细的说明,并结合大量的图表,展示了编译系统工作过程中代码信息的流动和存储格式的变化。是一本“手把手”教读者实现编译系统的贴心手册。

作品目录

  1. 前言
  2. 第1章 代码背后
  3. 1.1 从编程聊起
  4. 1.2 历史渊源
  5. 1.3 GCC的工作流程
  6. 1.3.1 预编译
  7. 1.3.2 编译
  8. 1.3.3 汇编
  9. 1.3.4 链接
  10. 1.4 设计自己的编译系统
  11. 1.5 本章小结
  12. 第2章 编译系统设计
  13. 2.1 编译程序的设计
  14. 2.1.1 词法分析
  15. 2.1.2 语法分析
  16. 2.1.3 符号表管理
  17. 2.1.4 语义分析
  18. 2.1.5 代码生成
  19. 2.1.6 编译优化
  20. 2.2 x86指令格式
  21. 2.3 ELF文件格式
  22. 2.4 汇编程序的设计
  23. 2.4.1 汇编词法、语法分析
  24. 2.4.2 表信息生成
  25. 2.4.3 指令生成
  26. 2.5 链接程序的设计
  27. 2.5.1 地址空间分配
  28. 2.5.2 符号解析
  29. 2.5.3 重定位
  30. 2.6 本章小结
  31. 第3章 编译器构造
  32. 3.1 词法分析
  33. 3.1.1 扫描器
  34. 3.1.2 词法记号
  35. 3.1.3 有限自动机
  36. 3.1.4 解析器
  37. 3.1.5 错误处理
  38. 3.2 语法分析
  39. 3.2.1 文法定义
  40. 3.2.2 递归下降子程序
  41. 3.2.3 错误处理
  42. 3.3 符号表管理
  43. 3.3.1 符号表数据结构
  44. 3.3.2 作用域管理
  45. 3.3.3 变量管理
  46. 3.3.4 函数管理
  47. 3.4 语义分析
  48. 3.4.1 声明与定义语义检查
  49. 3.4.2 表达式语义检查
  50. 3.4.3 语句语义检查
  51. 3.4.4 错误处理
  52. 3.5 代码生成
  53. 3.5.1 中间代码设计
  54. 3.5.2 程序运行时存储
  55. 3.5.3 函数定义与return语句翻译
  56. 3.5.4 表达式翻译
  57. 3.5.5 复合语句与break、continue语句翻译
  58. 3.5.6 目标代码生成
  59. 3.5.7 数据段生成
  60. 3.6 本章小结
  61. 第4章 编译优化
  62. 4.1 数据流分析
  63. 4.1.1 流图
  64. 4.1.2 数据流分析框架
  65. 4.2 中间代码优化
  66. 4.2.1 常量传播
  67. 4.2.2 复写传播
  68. 4.2.3 死代码消除
  69. 4.3 寄存器分配
  70. 4.3.1 图着色算法
  71. 4.3.2 变量栈帧偏移计算
  72. 4.4 窥孔优化
  73. 4.5 本章小结
  74. 第5章 二进制表示
  75. 5.1 x86指令
  76. 5.1.1 指令前缀
  77. 5.1.2 操作码
  78. 5.1.3 ModR/M字段
  79. 5.1.4 SIB字段
  80. 5.1.5 偏移
  81. 5.1.6 立即数
  82. 5.1.7 AT&T汇编格式
  83. 5.2 ELF文件
  84. 5.2.1 文件头
  85. 5.2.2 段表
  86. 5.2.3 程序头表
  87. 5.2.4 符号表
  88. 5.2.5 重定位表
  89. 5.2.6 串表
  90. 5.3 本章小结
  91. 第6章 汇编器构造
  92. 6.1 词法分析
  93. 6.1.1 词法记号
  94. 6.1.2 有限自动机
  95. 6.2 语法分析
  96. 6.2.1 汇编语言程序
  97. 6.2.2 数据定义
  98. 6.2.3 指令
  99. 6.3 符号表管理
  100. 6.3.1 数据结构
  101. 6.3.2 符号管理
  102. 6.4 表信息生成
  103. 6.4.1 段表信息
  104. 6.4.2 符号表信息
  105. 6.4.3 重定位表信息
  106. 6.5 指令生成
  107. 6.5.1 双操作数指令
  108. 6.5.2 单操作数指令
  109. 6.5.3 零操作数指令
  110. 6.6 目标文件生成
  111. 6.7 本章小结
  112. 第7章 链接器构造
  113. 7.1 信息收集
  114. 7.1.1 目标文件信息
  115. 7.1.2 段数据信息
  116. 7.1.3 符号引用信息
  117. 7.2 地址空间分配
  118. 7.3 符号解析
  119. 7.3.1 符号引用验证
  120. 7.3.2 符号地址解析
  121. 7.4 重定位
  122. 7.5 程序入口点与运行时库
  123. 7.6 可执行文件生成
  124. 7.7 本章小结
  125. 参考文献
载入中

大家都喜欢