重构手法62:Extract Subclass (提炼子类)

类中的某些特性只被某些实例用到。新建一个子类,将上面所说的那一部分特性移到子类中。

动机:使用Extract Subclass (提炼子类)的主要动机是:你发现类中的某些行为只被一部分实例用到,其他实例不需要它们。有时候这种行为上的差异是通过类型码区分的,此时你可以使用Replace Type Code with Subclass (以子类取代类型码)或Replace Type Code with State/Strategy (以状态策略取代类型码)。但是,并非一定要出现了类型码才表示需要考虑使用子类。

       Extract Class (提炼类)是Extract Subclass (提炼子类)之外的另一个选择,2者之间的抉择其实就是委托和继承之间的抉择。Extract Subclass (提炼子类)通常更容易进行,但它也有限制:一旦对象创建完成你无法再改变与类型的相关行为,但如果使用Extract Class (提炼类),你只需插入另一个组件就可以改变对象的行为。此外,子类只能用以表现一组变化。如果你希望一个类以几种不同的方式变化,就必须使用委托。

 

你可能感兴趣的:(subClass)