重构 改善既有代码的设计

 最近接手一个项目,源代码的架构和许多设计都有坏的味道。 想要重构,可是本身并无足够的底气.算法

1、重构的纠结:设计模式

(1)现有代码可用,你重构后是否会比如今更有效率;数组

(2)项目进度比较紧,你是否要抽出时间作这种没有KPI的工做;session

(3)你重构后,别人须要从新阅读你的源代码,给同事带来了从新学习代码的工做量;架构

(4)项目是否可以持续,若是没有需求,不用了,你还重构什么?app

(5)你是否要在这个公司待好久,等重构完后,你可能都不在了。框架

 

 2、若是不重构,确实会给开发带来很大困难:ide

原代码就像是一个打满了补丁的棉袄,它能够保暖,可是很难定位到哪里漏风,即便定位到了,不过是新打些补丁,可是缝缝补补的工做可能没有尽头。函数

(1)修改很耗精力;性能

(2)BUG花样迭出

(3)扩展性差,持续开发跟进需求很难;

(4)应变能力差,牵一发动全身。

 

重构或不重构,这是个问题,直到看了《重构 改善既有代码的设计》,给了我很大启发。粗略看了一遍,道理明白了一些,我以前的想法应该叫作重写而不是重构。

重构是逐步改善的过程,是重写与打补丁的中间选项。

固然看完书以后,我仍是选择了重写,由于项目还不是很大,重写作起来工做量更小一些。

重构的核心仍是使代码尽可能遵循设计模式的六大原则:

(1)单一职责原则
(2)里氏替换原则
(3)依赖倒置原则
(4)接口隔离原则
(5)迪米特法则
(6)开闭原则

重构中用到的方法,是写代码过程当中很好的参照。方法都写在2-13章的目录里了,意思比较明显,闲来的时候看看,也大有裨益。

第2章 重构原则
2.1 何谓重构53
2.2 为什么重构55
2.3 什么时候重构57
2.4 怎么对经理说60
2.5 重构的难题62
2.6 重构与设计66
2.7 重构与性能69
2.8 重构起源何处71
第3章 代码的坏味道
3.1 DuplicatedCode(重复代码)76
3.2 LongMethod(过长函数)76
3.3 LargeClass(过大的类)78
3.4 LongParameterList(过长参数列)78
3.5 DivergentChange(发散式变化)79
3.6 ShotgunSurgery(霰弹式修改)80
3.7 FeatureEnvy(依恋情结)80
3.8 DataClumps(数据泥团)81
3.9 PrimitiveObsession(基本类型偏执)81
3.10 SwitchStatements(switch惊悚现身)82
3.11 ParallelInheritanceHierarchies(平行继承体系)83
3.12 LazyClass(冗赘类)83
3.13 SpeculativeGenerality(夸夸其谈将来性)83
3.14 TemporaryField(使人迷惑的暂时字段)84
3.15 MessageChains(过分耦合的消息链)84
3.16 MiddleMan(中间人)85
3.17 InappropriateIntimacy(狎昵关系)85
3.18 AlternativeClasseswithDifferentInterfaces(殊途同归的类)85
3.19 IncompleteLibraryClass(不完美的库类)86
3.20 DataClass(纯稚的数据类)86
3.21 RefusedBequest(被拒绝的遗赠)87
3.22 Comments(过多的注释)87
第4章 构筑测试体系
4.1 自测试代码的价值89
4.2 JUnit测试框架91
4.3 添加更多测试97
第5章 重构列表
5.1 重构的记录格式103
5.2 寻找引用点105
5.3 这些重构手法有多成熟106
第6章 从新组织函数
6.1 ExtractMethod(提炼函数)110
6.2 InlineMethod(内联函数)117
6.3 InlineTemp(内联临时变量)119
6.4 ReplaceTempwithQuery(以查询取代临时变量)120
6.5 IntroduceExplainingVariable(引入解释性变量)124
6.6 SplitTemporaryVariable(分解临时变量)128
6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131
6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135
6.9 SubstituteAlgorithm(替换算法)139
第7章 在对象之间搬移特性
7.1 MoveMethod(搬移函数)142
7.2 MoveField(搬移字段)146
7.3 ExtractClass(提炼类)149
7.4 InlineClass(将类内联化)154
7.5 HideDelegate(隐藏“委托关系”)157
7.6 RemoveMiddleMan(移除中间人)160
7.7 IntroduceForeignMethod(引入外加函数)162
7.8 IntroduceLocalExtension(引入本地扩展)164
第8章 从新组织数据
8.1 SelfEncapsulateField(自封装字段)171
8.2 ReplaceDataValuewithObject(以对象取代数据值)175
8.3 ChangeValuetoReference(将值对象改成引用对象)179
8.4 ChangeReferencetoValue(将引用对象改成值对象)183
8.5 ReplaceArraywithObject(以对象取代数组)186
8.6 DuplicateObservedData(复制“被监视数据”)189
8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改成双向关联)197
8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改成单向关联)200
8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204
8.10 EncapsulateField(封装字段)206
8.11 EncapsulateCollection(封装集合)208
8.12 ReplaceRecordwithDataClass(以数据类取代记录)217
8.13 ReplaceTypeCodewithClass(以类取代类型码)218
8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223
8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227
8.16 ReplaceSubclasswithFields(以字段取代子类)232
第9章 简化条件表达式
9.1 DecomposeConditional(分解条件表达式)238
9.2 ConsolidateConditionalExpression(合并条件表达式)240
9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片断)243
9.4 RemoveControlFlag(移除控制标记)245
9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250
9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255
9.7 IntroduceNullObject(引入Null对象)260
9.8 IntroduceAssertion(引入断言)267
第10章 简化函数调用
10.1 RenameMethod(函数更名)273
10.2 AddParameter(添加参数)275
10.3 RemoveParameter(移除参数)277
10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279
10.5 ParameterizeMethod(令函数携带参数)283
10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285
10.7 PreserveWholeObject(保持对象完整)288
10.8 ReplaceParameterwithMethods(以函数取代参数)292
10.9 IntroduceParameterObject(引入参数对象)295
10.10 RemoveSettingMethod(移除设值函数)300
10.11 HideMethod(隐藏函数)303
10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304
10.13 EncapsulateDowncast(封装向下转型)308
10.14 ReplaceErrorCodewithException(以异常取代错误码)310
10.15 ReplaceExceptionwithTest(以测试取代异常)315
第11章 处理归纳关系
11.1 PullUpField(字段上移)320
11.2 PullUpMethod(函数上移)322
11.3 PullUpConstructorBody(构造函数本体上移)325
11.4 PushDownMethod(函数下移)328
11.5 PushDownField(字段下移)329
11.6 ExtractSubclass(提炼子类)330
11.7 Extract Superclass (提炼超类) 336
11.8 Extract Interface (提炼接口) 341
11.9 Collapse Hierarchy (折叠继承体系) 344
11.10 FormTemplateMethod(塑造模板函数) 345
11.11 Replace Inheritance with Delegation(以委托取代继承) 352
11.12 Replace Delegation with Inheritance (以继承取代委托) 355
第12章 大型重构
12.1 Tease Apart Inheritance (梳理并分解继承体系) 362
12.2 Convert Procedural Design to Objects (将过程化设计转化为对象设计) 368
12.3 Separate Domain from Presentation (将领域和表述/显示分离) 370
12.4 Extract Hierarchy (提炼继承体系) 375
相关文章
相关标签/搜索