Extract Subclass(提炼子类)

来源:互联网 发布:全基因组数据分析 编辑:程序博客网 时间:2024/05/16 07:51

类中的某些特性只被某些(而非全部)实例用到。
*新建一个子类,将上面所说的那一部分特性移到子类中*
这里写图片描述

1. 动机

1.主要动机:你发现类中的某些行为只被一部分实例用到,其他实例不需要它们。
2. Extract Class(提炼类)是Extract Subclass之外的另一种选择,两者之间的抉择其实就是委托和继承之间的抉择。Extract Subclass通常更容易进行,但它也有限制:一旦对象创建完成,你无法再改变与类型相关的行为。此外,子类只能用以表现一组变化。如果你希望一个类以集中不同的方式变化,就必须使用委托。

2.做法

  1. 为源类定义一个新的子类。
  2. 为这个新的子类提供构造函数。
    1)简单的做法是:让子类构造函数接收与超累构造函数相同的参数,并通过super调用超类构造函数。
    2)如果你希望对用户隐藏子类的存在,可使用Replace Constructor with Factory Method(以工厂函数取代构造函数:你希望在创建爱你对象时不仅仅是做简单的建构动作,将构造函数替换为工厂函数)。
  3. 找出调用超类构造函数的所有地点。如果它们需要的是新建的子类,令它们改而调用新构造函数。
  4. 逐一使用Push Down Method(函数下移:超类中的某个函数只与部分(而非全部)子类有关,将这个函数移到相关的那些子类去。)和Push Down Field(字段下移:超类中的某个字段只与部分(而非全部)子类有关,将这个字段移到相关的那些子类去)将源。)类的特性移到子类去。
    1)先处理函数在处理数据简单。
    2)当一个public函数被下移到子类后,你可能需要重新定义该函数的调用端的局部变量或参数类型,让它们改而调用子类中的新函数。
  5. 找到所有这样的字段:它们所传达的信息如今可由继承体系自身传达(这一类字段通常是bool变量或类型码)。
  6. 每次下移之后,编译并测试。
原创粉丝点击