搜索
高级检索
高级搜索
书       名 :
著       者 :
出  版  社 :
I  S  B  N:
文献来源:
出版时间 :
软件驱魔:调试和优化遗留代码的艺术:a handbook for debugging and optimizing legacy code
0.00    
图书来源: 浙江图书馆(由图书馆配书)
  • 配送范围:
    全国(除港澳台地区)
  • ISBN:
    9787111462842
  • 作      者:
    (美)Bill Blunden著
  • 出 版 社 :
    机械工业出版社
  • 出版日期:
    2014
收藏
编辑推荐

  Amazon五星级畅销书,遗留代码调试和优化领域的代表性著作,资深专家10余年经验结晶,长销不衰不仅从实用性角度深入、系统地讲解了调试和优化遗留代码的方法、技术和最佳实践,而且从源头上告知读者如何避免掉进维护遗留代码的泥潭。


更多精彩,点击进入品牌店查阅>>


展开
作者简介

  Bill Blunden,拥有康奈尔大学物理学学士学位和凯斯西储大学运筹学硕士学位。资深系统维护专家,从事相关工作10余年,对系统软件的维护、遗留代码的调试和优化有非常深入的研究。活跃于计算机安全类社区,常与计算机安全领域多名世界级安全专家交流探讨。

展开
内容介绍

  《软件驱魔:调试和优化遗留代码的艺术》是遗留代码调试和优化领域的代表性著作,是作者10多年来在软件bug中“驱魔”经验的结晶,Amazon五星评论。不仅从实用性角度深入、系统地讲解了调试和优化遗留代码的方法、技术和最佳实践,而且从源头上阐述如何避免掉进维护遗留代码的泥潭,编写出易于维护,甚至不需要维护的高质量代码。
  《软件驱魔:调试和优化遗留代码的艺术》共分7章:第1章介绍用于构建易于修改和调试的软件的相关技术;第2章讲解如何定位和消除软件bug;第3章提供理解问题以及程序的有用方法;第4章讲述调试器在计算机内部的工作原理;第5章深入探讨优化内存的相关技术和方法;第6章则探讨如何从CPU运行效率的角度优化代码的经验和技术;第7章结合社会和环境因素给出一些宝贵的建议。

展开
精彩书摘

  第1章
  预 防 药
  概要
  老实说,相比那些在事后马虎的人而言,对那些在一开始就马马虎虎的人我会毫不犹豫地将其淘汰掉。这听起来相当冷酷无情,这的确冷酷无情。但是,这并不是那种“如果你无法忍受炙热,那就远离厨房”的提醒,它更深刻。我不愿与那些马马虎虎的人共事。这是软件开发的进化论。
  —— Linus Torvalds 在Linux内核邮件列表里关于内核调试器的讨论中如是说
  维护工程师的角色是驱逐那些潜藏在遗留软件里的邪恶幽灵,他们夜以继日维护着那些软件,上下交困,怨声载道,就像在穿过公司的那条小径上孤独前行。每天,他们都面临诸如:
  修复bug
  性能提升
  这样的挑战。本书前面4章会重点关注于前者。最后两章会关注后者。
  在1896年出版的一本名为 《Hawkin’s New Catechism of Electricity》 的电气手册中,首次提出bug这个术语,“在有限范围内,用于指明与电气设备相关的或电气设备工作中出现的任何缺陷故障”。这个术语在Rear Admiral Grace Murray Hopper(COBOL语言的发明者) 的帮助下逐步进化成用于表示计算机程序的故障。
  与bug打交道是程序员最讨厌的工作任务之一。基于此,处理软件bug最好的时机就是在软件的实现阶段。换句话说就是,在问题即将成为软件发行版本中的一部分之前, 这些bug还没有“潜伏”到软件中,就修复它,这样,维护工程师在后续的工作中,就不用再陷入处理这些问题的烦恼中。包括Linus Torvalds在内的很多专业人士,都认同这套思路。
  《孙子兵法》有云:“上兵伐谋,其次伐交,其次伐兵,其下攻城。攻城之法,为不得已。”解决大问题固然重要,杜绝小问题同样不可小视;解决大问题彰显才华卓越,杜绝小问题更显先见之明。作为软件工程师,要有远见,尽早地实现缺陷的隔离和修复。这样,你就不用再担心凌晨3点钟还会接到来自愤怒的系统管理员的电话。
  本章讨论用于减少代码受到bug影响的预防性测量。如果你是正在参与构建一个全新软件的工程师,或者你正在新增软件特性,那么,你需要认真地阅读本章。此外,如果你已经接手了你从未写过的一个应用(并且这种情况应该很常见),那么,我推荐你先跳过本章,从下一章开始。一旦你处理完那些讨厌的bug,你可以再回到本章,使用本章介绍的技术来帮助你清理补丁程序。

  ……

展开
目录

译者序
前言
第1章 预防药 1
1.1?核心问题 2
1.1.1 上市时间的压力 2
1.1.2 不确定的规格说明 4
1.1.3 以功能特性换时间 5
1.1.4 写下来 5
1.1.5 复杂性 8
1.2 防御性编程 9
1.2.1 内聚和耦合 9
1.2.2 错误输入检查 12
1.2.3 数据范围 18
1.2.4 日志 20
1.2.5 文档 28
1.2.6 为改变而设计 31
1.2.7 增量精炼 33
1.3 单元测试 34
1.3.1 自动化测试的动机 35
1.3.2 实现框架的步骤 36
1.3.3 框架扩展 43
1.4 工具的配置 46
1.4.1 使用编译器警告 46
1.4.2 发行版本的设置 47
1.5 机器相关性 48
1.5.1 字节序 49
1.5.2 内存对齐 50
1.5.3 数据类型大小 51
1.5.4 虚拟机的好处 52
1.6 小结 53
1.6.1 底线:为什么出现bug 54
1.6.2 改进清单:bug主动预防 54


第2章 调试技巧 55
2.1 初始步骤 56
2.1.1 复现问题 56
2.1.2 无法复现的问题 56
2.1.3 验证bug是真实存在的 59
2.2 消除缺陷:快速修复 60
2.2.1 检查近期改动 60
2.2.2 使用跟踪信息 61
2.2.3 似曾相识 61
2.2.4 明确何时放弃 61
2.3 消除缺陷:科学方法论 62
2.3.1 一般步骤 62
2.3.2 定位问题:增量集成法 63
2.3.3 定位问题:二分法 64
2.3.4 理解问题 64
2.3.5 防范失误 65
2.3.6 诊断工具 67
2.3.7 基础调试操作 75
2.4 保留记录 80
2.4.1 个人记录 80
2.4.2 协同开发下的记录 81
2.5 小结 84


第3章 理解问题 86
3.1 知识是如何丢失的 87
3.1.1 竞争 87
3.1.2 人员流失 89
3.1.3 升职 90
3.2 难懂的代码 91
3.2.1 设计问题 91
3.2.2 混淆 95
3.2.3 误导性的代码 104
3.3 反向工程 105
3.3.1 通用策略 105
3.3.2 对策 111
3.3.3 建立知识库 116
3.4 小结 118


第4章 调试器内部机制 119
4.1 调试器的种类 119
4.1.1 机器调试器与符号调试器 119
4.1.2 调试基础:自定义构建 125
4.1.3 调试基础:系统调用 136
4.1.4 调试基础:解释器 151
4.1.5 内核调试器 155
4.1.6 界面:命令行与图形用户界面 157
4.2 符号调试器扩展 157
4.2.1 动态断点 157
4.2.2 单步执行 158
4.3 应对策略 159
4.3.1 系统调用 159
4.3.2 移除调试信息 160
4.3.3 代码盐 161
4.3.4 混合内存模型 162
4.4 小结 163


第5章 优化:内存占用 165
5.1 被遗忘的历史 167
5.2 程序的内存布局 168
5.2.1 场景:单段程序 169
5.2.2 场景:仅代码段和数据段 170
5.2.3 场景:所有4种段类型 171
5.3 代码段 172
5.3.1 剪切粘贴式编程 172
5.3.2 宏 175
5.3.3 僵尸代码 177
5.4 数据段 177
5.4.1 双重用途的数据结构 178
5.4.2 位域 180
5.4.3 压缩算法 181
5.5 栈 183
5.5.1 活动记录 184
5.5.2 函数参数 188
5.5.3 局部变量 190
5.6 堆 191
5.6.1 内存池 192
5.6.2 回收 196
5.6.3 延迟实例化 197
5.6.4 跟踪内存使用情况 199
5.7 小结 201


第6章 优化:CPU周期 202
6.1 程序控制跳转 203
6.1.1 标签与GOTO 203
6.1.2 函数参数 205
6.1.3 带可变参数的函数 206
6.1.4 系统调用 207
6.1.5 递归 210
6.2 程序控制分支 211
6.2.1 查找表 211
6.2.2 switch与if-else 213
6.2.3 常见情况放在前,罕见情况放在后 215
6.3 程序控制循环 215
6.3.1 循环不变量 216
6.3.2 函数调用 217
6.3.3 数组引用 219
6.3.4 分解复合布尔表达式 220
6.3.5 循环展开 221
6.3.6 循环干涉 221
6.3.7 提取程序分支语句 221
6.4 内存管理 222
6.4.1 处理开销 223
6.4.2 引用局部性 226
6.5 输入/输出 227
6.5.1 缓存 228
6.5.2 缓冲 229
6.5.3 先进的技术 230
6.6 异常 231
6.6.1 动态注册模型 234
6.6.2 静态表模型 235
6.6.3 处理开销 235
6.6.4 滥用异常 237
6.7 昂贵的操作 237
6.7.1 消除常见的子表达式 237
6.7.2 浮点运算神话 237
6.7.3 强度折减 239
6.7.4 同步 240
6.7.5 简写操作符的神话 243
6.8 快速修复 243
6.8.1 更好的硬件 243
6.8.2 约束问题 244
6.8.3 编译器设置 244
6.9 小结 245
6.10 信息汇总 246


第7章 最后的赠言 247
7.1 对于源代码完整性的其他威胁 248
7.1.1 时髦技术:一个案例研究 248
7.1.2 洗脑101 249
7.1.3 真正的问题 249
7.2 保持书面记录 250
7.2.1 悄悄记录 250
7.2.2 隐私的神话 250
7.3 历史总是重演 251

展开
加入书架成功!
收藏图书成功!
我知道了(3)
发表书评
读者登录

请选择您读者所在的图书馆

选择图书馆
浙江图书馆
点击获取验证码
登录
没有读者证?在线办证