重构是在不改变软件外部行为的前提下,对其内部结构进行改变,使之更容易理解并便于修改。
代码重复、程序太长、嵌套过深、参数太多、接口抽象不一致、变化导致多个地方同时修改...MS理由很多很多,其实说白了,当代码看不懂的时候,往往就预示着代码需要重构了。
数据级的重构->语句级的重构->子程序级的重构->类实现的重构->类接口的重构->系统级的重构。
做什么事情往往都是从简到难,从局部到整体,重构也一样,即然说的是对内部结构进行改变,那么最直接的修改就应该是从最里面开始。
数据级的重构:具名变量代替神秘数值、表达式内联化、使用变量的名字传递更多更清晰的信息、函数代替表达式、引入中间变量、多个单一用变量代替某个多用途变量、局部用途中使用局部变量而非参数、基础数据类型化为类、一组类型码转为枚举或类、数组转为对象、群集封装起来、数据类代替传统记录
语句级的重构:分解布尔表达式、复杂布尔表达式转换为布尔函数、合并条件语句中不同部分的重复代码、使用break或return而不是循环控制变量、多态来代替条件语句、条件语句即刻返回、创建和使用null对象而不是检测空值
子程序级重构:提取子程序或方法、子程序的内联化、冗长的子程序转为类、简化算法、增加或删除参数、合并相似的子程序、拆分子程序、传递整个对象而非特定成员、包装向下转型的操作
类的重构:值对象和引用对象相互转化、数据初始化代替虚函数、改变成员函数或数据成员的位置、特殊代码提取为派生类、相似代码提取到基类。
类接口的重构:成员函数移到另一个类、分解类、删除类、去除委托关系、去掉中间对象、委托和继承相互转换、引入外部成员变量、引入扩展类、隐藏不实用的成员函数、合并相似的类
系统级的重构:单向的类关系和双向的相互转换、用工厂模式、异常取代错误处理代码
安全的重构:保存初始代码、重构的步伐笑点、同一时间只做一项重构、把想做的事一条条列出来、多使用检查点和快照、重新测试、增加测试用例、检查对代码的修改