图书介绍

代码整洁之道【2025|PDF|Epub|mobi|kindle电子书版本百度云盘下载】

代码整洁之道
  • (美)RobertC.Martin编著 著
  • 出版社: 北京:人民邮电出版社
  • ISBN:9787115216878
  • 出版时间:2010
  • 标注页数:389页
  • 文件大小:19MB
  • 文件页数:408页
  • 主题词:软件开发

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
种子下载[BT下载速度快]温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页直链下载[便捷但速度慢]  [在线试读本书]   [在线获取解压码]

下载说明

代码整洁之道PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

第1章 整洁代码1

1.1要有代码2

1.2糟糕的代码2

1.3混乱的代价3

1.3.1华丽新设计4

1.3.2态度4

1.3.3迷题5

1.3.4整洁代码的艺术5

1.3.5什么是整洁代码6

1.4思想流派10

1.5我们是作者11

1.6童子军军规12

1.7前传与原则12

1.8小结12

1.9文献13

第2章 有意义的命名15

2.1介绍15

2.2名副其实16

2.3避免误导17

2.4做有意义的区分18

2.5使用读得出来的名称19

2.6使用可搜索的名称20

2.7避免使用编码21

2.7.1匈牙利语标记法21

2.7.2成员前缀21

2.7.3接口和实现22

2.8避免思维映射22

2.9类名23

2.10方法名23

2.11别扮可爱23

2.12每个概念对应一个词24

2.13别用双关语24

2.14使用解决方案领域名称25

2.15 使用源自所涉问题领域的名称25

2.16添加有意义的语境25

2.17不要添加没用的语境27

2.18最后的话27

第3章 函数29

3.1短小32

3.2只做一件事33

3.3每个函数一个抽象层级34

3.4 switch语句35

3.5使用描述性的名称36

3.6函数参数37

3.6.1一元函数的普遍形式38

3.6.2标识参数38

3.6.3二元函数38

3.6.4三元函数39

3.6.5参数对象39

3.6.6参数列表40

3.6.7动词与关键字40

3.7无副作用40

3.8分隔指令与询问42

3.9使用异常替代返回错误码42

3.9.1抽离Try/Catch代码块43

3.9.2错误处理就是一件事44

3.9.3 Error.java依赖磁铁44

3.10别重复自己44

3.11结构化编程45

3.12如何写出这样的函数45

3.13小结45

3.14 SetupTeardownIncluder程序46

3.15 文献48

第4章 注释49

4.1注释不能美化糟糕的代码50

4.2用代码来阐述51

4.3好注释51

4.3.1法律信息51

4.3.2提供信息的注释51

4.3.3对意图的解释52

4.3.4阐释53

4.3.5警示53

4.3.6 TODO注释54

4.3.7放大54

4.3.8公共API中的Javadoc55

4.4坏注释55

4.4.1喃喃自语55

4.4.2多余的注释56

4.4.3误导性注释58

4.4.4循规式注释58

4.4.5日志式注释59

4.4.6废话注释59

4.4.7可怕的废话61

4.4.8能用函数或变量时就别用注释62

4.4.9位置标记62

4.4.10括号后面的注释62

4.4.11归属与署名63

4.4.12注释掉的代码63

4.4.13 HTML注释64

4.4.14非本地信息64

4.4.15 信息过多65

4.4.16不明显的联系65

4.4.17函数头66

4.4.18非公共代码中的Javadoc66

4.4.19范例66

4.5文献69

第5章 格式71

5.1格式的目的72

5.2垂直格式72

5.2.1向报纸学习73

5.2.2概念间垂直方向上的区隔73

5.2.3垂直方向上的靠近74

5.2.4垂直距离75

5.2.5垂直顺序79

5.3横向格式79

5.3.1水平方向上的区隔与靠近80

5.3.2水平对齐81

5.3.3缩进82

5.3.4空范围84

5.4团队规则84

5.5鲍勃大叔的格式规则85

第6章 对象和数据结构87

6.1数据抽象87

6.2数据、对象的反对称性89

6.3得墨忒耳律91

6.3.1火车失事91

6.3.2 混杂92

6.3.3隐藏结构92

6.4数据传送对象93

6.5小结94

6.6文献94

第7章 错误处理95

7.1使用异常而非返回码96

7.2先写Try-Catch-Finally语句97

7.3使用不可控异常98

7.4给出异常发生的环境说明99

7.5依调用者需要定义异常类99

7.6定义常规流程100

7.7别返回null值101

7.8别传递null值102

7.9小结103

7.10文献104

第8章 边界105

8.1使用第三方代码106

8.2浏览和学习边界107

8.3学习log4j108

8.4学习性测试的好处不只是免费110

8.5使用尚不存在的代码110

8.6整洁的边界111

8.7文献112

第9章 单元测试113

9.1 TDD三定律114

9.2保持测试整洁115

9.3整洁的测试116

9.3.1面向特定领域的测试语言118

9.3.2双重标准119

9.4每个测试一个断言121

9.5 F.I.R.S.T122

9.6小结123

9.7文献124

第10章类125

10.1类的组织126

10.2类应该短小126

10.2.1单一权责原则128

10.2.2内聚129

10.2.3保持内聚性就会得到许多短小的类130

10.3为了修改而组织136

10.4文献139

第11章 系统141

11.1如何建造一个城市142

11.2将系统的构造与使用分开142

11.2.1分解main143

11.2.2工厂143

11.2.3依赖注入144

11.3扩容145

11.4 Java代理148

11.5纯Java AOP框架150

11.6 AspectJ的方面152

11.7测试驱动系统架构153

11.8优化决策154

11.9明智使用添加了可论证价值的标准154

11.10系统需要领域特定语言154

11.11小结155

1112文献155

第12章 迭进157

12.1通过迭进设计达到整洁目的157

12.2简单设计规则1:运行所有测试158

12.3简单设计规则2~4:重构158

12.4不可重复159

12.5表达力161

12.6尽可能少的类和方法162

12.7小结162

12.8文献162

第13章 并发编程163

13.1为什么要并发164

13.2挑战165

13.3并发防御原则166

13.3.1单一权责原则166

13.3.2推论:限制数据作用域166

13.3.3推论:使用数据复本167

13.3.4推论:线程应尽可能地独立167

13.4了解Java库167

13.5了解执行模型168

13.5.1生产者-消费者模型169

13.5.2读者-作者模型169

13.5.3宴席哲学家169

13.6警惕同步方法之间的依赖169

13.7保持同步区域微小170

13.8很难编写正确的关闭代码170

13.9测试线程代码171

13.9.1将伪失败看作可能的线程问题171

13.9.2先使非线程代码可工作171

13.9.3编写可插拔的线程代码172

13.9.4编写可调整的线程代码172

13.9.5运行多于处理器数量的线程172

13.9.6在不同平台上运行172

13.9.7装置试错代码173

13.9.8硬编码173

13.9.9自动化174

13.10小结175

13.11文献175

第14章 逐步改进176

14.1 Args的实现177

14.2 Args:草稿183

14.2.1所以我暂停了195

14.2.2渐进195

14.3字符串参数197

14.4小结234

第15章JUnit内幕235

15.1 JUnit框架236

15.2小结249

第16章 重构SerialDate251

16.1首先让它能工作252

16.2让它做对254

16.3小结266

16.4文献267

第17章 味道与启发269

17.1注释270

17.2环境271

17.3函数271

17.4一般性问题272

17.5 Java288

17.6名称291

17.7测试294

17.8小结295

17.9文献296

附录A并发编程Ⅱ297

A.1客户端/服务器的例子297

A.1.1服务器297

A.1.2添加线程代码298

A.1.3观察服务器端299

A.1.4小结301

A.2执行的可能路径301

A.2.1路径数量302

A.2.2深入挖掘303

A.2.3小结305

A.3了解类库305

A.3.1 Executor框架305

A.3.2非锁定的解决方案306

A.3.3非线程安全类307

A.4方法之间的依赖可能破坏并发代码308

A.4.1容忍错误309

A.4.2基于客户代码的锁定309

A.4.3基于服务端的锁定311

A.5提升吞吐量312

A.5.1单线程条件下的吞吐量313

A.5.2多线程条件下的吞吐量313

A.6死锁314

A.6.1互斥315

A.6.2上锁及等待315

A.6.3无抢先机制315

A.6.4循环等待315

A.6.5不互斥316

A.6.6不上锁及等待316

A.6.7满足抢先机制317

A.6.8不做循环等待317

A.7测试多线程代码317

A.8测试线程代码的工具支持320

A.9小结320

A.10教程:完整代码范例321

A.10.1客户端/服务器非线程代码321

A.10.2使用线程的客户端/服务器代码324

附录B org.jfree.date.SerialDate327

结束语389

热门推荐