7.3extract class(提炼类)

某个类做了应该由两个类做的事。

建立一个新类,将相关的字段和函数从旧类搬移到新类。

动机:

如果某些数据和某些函数总是一起出现,某些数据经常同时变化甚至彼此相依,这就表示你应该将它们分离出去。

如果子类化只影响类的部分特性,或如果发现某些特性需要以一种方式来子类化,某些特性则需要以另一种方式子类化,需要分解原来的类。

做法:

决定如何分解类所负的责任。

建立一个新类,用以表现从就类中分离出来的责任。

=》如果旧类剩下的责任与旧类名不符,为旧类更名。

建立“从旧类访问新类”的连接关系。

=》有可能需要一个双向连接。但是在真正需要它之前,不要建立“从新类通完旧类”的连接。

对于你想搬移的每一个字段,运用move field。

使用move method搬移到新类。先搬移较低层次函数,再搬移较高层次函数。

检查,精简每个类的接口。

=》如果建立起双向连接,检查是否可以将它改为单向连接。

决定是否公开新类。如果需要公开,决定让它成为引用对象还是不可变的值对象。

你可能感兴趣的:(7.3extract class(提炼类))