本博客主要是学习《重构-改善既有代码》时的笔记和心得。
当发现需要添加一个新的特性很麻烦的时候,阅读的很吃力,不好理解,看起来不优雅,不爽,就需要重构了。
对软件内部的一种调整,在不改变软件可观察的前提下,提高其可理解性,降低其修改成本。 开发过程中只做2件事:添加新功能和重构。不能同时做。
1.重复的代码 :提炼 2.过长的函数:分解 3.过大的类 :分类 4.过长的参数:尽量用 对象代替 5.发散式变化:就是说一个类 引起其变化的原因 有2个以上。 6.散弹式修改:就是说遇到某种变化时,许多类都要修改 7.依恋情节:函数对某个类的兴趣高过对自己所属的类。 8.数据泥团:总是绑在一起出现的数据应该拥有属于他们自己的对象。减少参数和字段的个数 9.基本类型偏执:尽量使用对象 代替 数值 10.switch现身:尽量少用switch,使用多态消除 11.平行继承体系:让一个继承体系的实例去引用另一个继承体系的实例 12.消除冗余类: 13.夸夸其谈未来性 14.令人迷惑的暂时字段:把这些变量和相关函数 提到一个新的类中 15.过度耦合的消息链:一个对象请求另一个,另一个又去请求另另一个。 16.中间人:过度的委托了 17.2个类之间过于亲密 18.异曲同工的类:2个函数做同一件事,却有2个不同的签名 19.不完美的类库 20.纯数据类: 21.被拒绝的遗赠:使用委托 代替不必要的继承 22.过多的注释:并不是说注释不好,而是 完美可以用好的代码去代替 注释
1.junit测试框架
就是重构时要从以下方面去思考:
名称概要动机做法范例1.提炼函数 extract method 2.内联函数 inline method 3.内联临时变量 inline temp 4.以查询取代临时变量replace temp with query 5.引入解释性变量introduce explain variable 6.分解临时变量split temporary variable 7.移除对参数的赋值remove assignments to parametes 8.以函数对象取代函数replace method with mehod object 9.替换算法substitute algorithm
1.搬移函数move method 2.搬移字段move field 3.提炼类extract class 4.将类内联化inline class 5.隐藏委托关系hide delegate 6.移除中间人remove middle man 7.引入外加函数introduce foreign method 8.引入本地扩展introduce local extension
1.自封装字段self encapsulate field 2.以对象取代数据值replace data value with object 3.将值对象改为引用对象change value to reference 4.将引用对象改为值对象change reference to value 5.以对象取代数组replace array with object 6.赋值被监视数据duplicate observed data 7.将单向关联改为双向关联 8.将双向关联改为单向关联 9.封装字段encapsulate field 10.封装集合encapsulate collection 11.以子类取代类型码 12.以类取代类型码 13.以状态或者策略模式取代类型码 14.以字段取代子类
1.分解条件表达式 2.合并条件表达式 3.合并重复的条件判断 4.移除控制标记 5.以卫语句取代嵌套条件表达式 6.以多态取代条件表达式 7.引入null对象 8.引入断言
1.函数改名 2.添加参数 3.移除参数 4.将查询函数与修改函数分离(避免函数有副作用) 5.以明确函数代替参数 6.保持对象完整 7.以函数代替参数 8.引入参数对象 9.移除设置函数 10.隐藏函数-修改访问控制符为private 11.以工厂函数取代构造函数 12.封装向下转型 13.以异常取代错误代码 14.以测试取代异常
1.字段上移 2.函数上移 3.构造函数本体上移 4.函数下移 5.字段下移 6.提炼子类 7.提炼超类 8.提炼接口 9.折叠继承体系 10.塑造模板函数 11.以委托取代继承 12.以继承取代委托
不是为了重构而重构,是要有明确的目的时才进行重构 四个大型重构方法: 1.梳理并分离继承体系 2.将过程化设计转化为对象设计 3.将领域和表述/显示分离-就是分层的思想如 mvc mvp mvvm 4.提炼继承体系-就是增加中间层
谨慎 和 2顶帽子 好的代码,是具有易扩展,易维护,健壮性,可读性,高内聚低耦合的特点。