臃肿类(Large Class)
●症状和特点
一个类中含有很多字段、方法或者很多行代码。
●问题产生的原因
通常情况下,最开始类的规模很小,但是随着时间的增长,它随着程序的扩展而变得臃肿。
这种情况就和长方法一样,程序员一般认为在类中添加一个新的特征比为了将来程序简洁而创造一个新的类更加省事。
●解决方法
当一个类有太多的代码时,可以考虑将它拆分:
如果这个庞大的类中的某一部分的行为可以被分解成单独的成分,可以使用类提炼法。
如果这个庞大的类的某一部分行为可以用不同的方式实行,或者只在少数的场景中用到,可以使用子类提炼法。
如果需要一套方法和行为来供客户使用,可以使用接口提炼法。
如果一个庞大的类需要为绘图接口负责,你可能尝试着将它的某些数据和行为分类到一个单独的对象区域中。为了实现它,你就要将数据的副本存放在两个地方,并且要保持两处数据的一致性。重复观测数据法为种情况提供了解决方案。
●优势
对这些类进行重构,省去了程序员去记住类中很多的成员属性的麻烦。
很多情况下,将臃肿的类拆分成几块避免了代码层面和功能层面的重复。