重构-改善既有的代码设计
博客专区 > 忆瑶 的博客 > 博客详情
重构-改善既有的代码设计
忆瑶 发表于5年前
重构-改善既有的代码设计
  • 发表于 5年前
  • 阅读 436
  • 收藏 10
  • 点赞 0
  • 评论 1

新睿云服务器60天免费使用,快来体验!>>>   

What?

   重构(名词):对软件内部结构的一种调整,目的是在不改变软件可观察行为的前提下,提高其可理解性,降低其修改成本。

  重构(动词): 使用一系列重构手法,在不改变软件可观察行为的前提下,调整其结构。

 Why?

 1. 重构改进软件设计

2.重构使软件更容易理解

3. 重构提高编程速度

When?

1.添加功能 时重构

如果你发现自己需要为程序添加一个特性,而代码结构使你无法很方便地达成目的,那就先重构那个程序,使特性的添加比较容易进行,然后再添加特性。

2.修补错误时重构

3.复审代码时重构

 How?

 1. 重构之前,首先检查自己是否有一套可靠的测试机制。这些测试必须有自我检测能力。

 2. 找 出代码的逻辑泥团并用Extract Method (Alt + Shift + R) 把它提炼到独立的函数中。

       2.1 首先找到函数内的局部变量和参数,任何不会被修改的变量都可以被当做参数传入新的函数,而会被修改的变量就需要格外小心。

       Tips:重构技术就是以微小的步伐修改程序。如果你犯下错误,很容易便可发现它。

       2.2 修改难以理解的变量名称,提高代码的清晰度。

       2.3 查看代码段是否放错了位置。绝大多数情况下,函数应该放在它所使用的数据的所属对象内。移动可以使用Move Method(Alt + Shift + V)先把代码复制到新类 调整代码然后重新编译。

      2.4 找出程序中对于旧函数的所有引用点,并修改它们,让它们改用新函数。做完之后,去掉旧函数。进行测试。

        有时候也可以保留旧函数,让它调用新函数。如果旧函数是一个public函数,而你又不想修改其他类的接口,这便是一个有用的手法。

代码的坏味道

      代码的坏味道

重构手法

  • 重新组织函数

         Introduce Explaining Variable (引入解释性变量)

          Split Temporary Variable (分解临时变量)

          Remove Assignments to Parameters (移除对参数的赋值)

          Replace Method with Method Object (以函数对象取代函数)

          Substitute Algorithm (替换算法)


  • 在对象之间搬移特性

               Move Method(搬移函数)

               Move Field (搬移字段)

               Extract Class (提炼类)

               Inline Class (将类内联化)

               Hide Delegate (隐藏"委托关系")

               Remove Middle Man (移除中间人)            

               Introduce Foreign Method (引入外加函数)

               Introduce Local Extension (引入本地扩展)

  • 重新组织数据

                Self Encapsulate Field (自封装字段)                

                Replace Data Value with Object (以对象取代数据值)

                Change Value to Reference (将值对象改为引用对象)

                Change Reference to Value (将引用对象改为值对象)

                Replace Array with Object (以对象取代数组)

                Duplicate Observed Data (复制“被监视数据”)

                Change Unidirectional Association to Bidirectional (将单向关联改为双向关联)

                Change Bidirectional Association to Unidirectional (将双向关联改为单向关联)

                Replace Magic Number with Symbolic Constant (以字面常量取代魔法数)

                Encapsulate Field (封装字段)

                Encapsulate Collection (封装集合)

                Replace Record with Data Class (以数据取代记录)

               Replace Type Code with Class (以类取代类型码)

               Replace Type Code with Subclasses (以子类取代类型码)

               Replace Type Code with State/Strategy (以State/Strategy取代类型码)

               Replace Subclass with Fields (以字段取代子类)

  • 简化条件表达式

                 Decompose Conditional (分解条件表达式)

                 Consolidate Conditional Expression (合并条件表达式)

                 Consolidate Duplicate Conditional Fragments (合并重复的条件片段)

                 Remove Control Flag (移除控制标记)

                 Replace Nested Conditional with Guard Clauses (以卫语句取代嵌套条件表达式)

                 Replace Conditional with Polymorphism (以多态取代条件表达式)

                 Introduce Null Object (引入Null对象)

                 Introduce Assertion (引入断言)

  • 简化函数调用

         Rename Method (函数改名)

        Add Parameter (添加参数)

        Remove Parameter (移除参数)

        Separate Query from Modifier (将查询函数和修改函数分离)

        Parameterize Method (令函数携带参数)

        Replace Parameter with Explicit Methods (以明确函数取代参数)

        Preserve Whole Object (保持对象完整)

        Replace Parameter with Methods (以函数取代参数)

        Introduce Parameter Object (引入参数对象)

        Remove Setting Method (移除设值函数)

        Hide Method (隐藏函数)

        Replace Constructor with Factory Method (以工厂函数取代构造函数)

        Encapsulate Downcast (封装向下转型)

        Replace Error Code with Exception (以异常取代错误码)

        Replace Exception with Test (以测试取代异常)

  • 处理概括关系

        Pull Up Field (字段上移)

        Pull Up Method (函数上移)

        Pull Up Constructor Body (构造函数本体上移)

        Push Down Method (函数下移)

        Push Down Field (字段下移)

        Extract Subclass (提炼子类)

        Extract Superclass (提炼超类)

        Extract Interface (提炼接口)

        Collapse Hierarchy (折叠继承体系)

        Form Template Method (塑造模板函数)

        Replace Inheritance with Delegation (以委托取代继承)

        Replace Delegation with Inheritance (以继承取代委托)


  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 19
博文 125
码字总数 99861
评论 (1)
忆瑶
不断更新中....
×
忆瑶
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: