Self Encapsulate Field 自封装字段
你直接访问一个字段,但与字段之间的耦合关系逐渐变得笨拙。
为这个字段建立取值/设置函数,并且只以这些函数来访问字段。
子类用超类数据时
Replace Data Value with Object 以对象取代数据值
你有一个数据项,需要与其他数据和行为一起使用才有意义
值对象应该是不可修改内容的
Change Value to Reference 将值对象改为引用对象
你从一个类衍生出许多彼此相等的实例,希望将它们替换为同一个对象
Change Reference to Value 将引用对象改为值对象
你有一个引用对象,很小且不可变,而且不易管理
Replace Array with Object 以对象取代数组
你有一个数组,其中的元素各自代表不同的东西
Duplicate Observed Data 复制“被监视数据”
你有一些领域数据置身与GUI控件中,而领域函数需要访问这些数据。
将该数据复制到一个领域对象中。建立一个Observer模式,用以同步领域对象和GUI对象内的重复数据。
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 以策略模式取代类型码
类型码影响类行为,且无法通过继承手法消除它。
以状态对象取代类型码
Replace SubClass with Fields 以字段取代子类
各个子类的唯一差别只在“返回常量数据”的函数身上。
修改这些函数,使他们返回超类中的某个(新增)字段
说明
《重构-改善既有代码的设计》Martin Fowler 摘要: 第八章 重新组织数据
你也可以访问:http://txidol.github.io 获取更多的信息