在对象之间搬移特性

搬移函数

在程序中,有个函数与其所驻类之外的另一个类交流更多:调用后者,或者被后者调用。这个时候可以使用 Move Method(搬移函数) 在该函数最长引用的类中建立一个有着类似行为的新函数。将就函数变成一个单纯的委托函数,或是将旧函数完全移除。

1551665208394

搬移字段

在程序中,某个字段被其所驻类之外的另一个类更多地用到。这个时候可以使用 Move Field(搬移字段) 在目标类新建一个字段,修改源字段的所有用户,令它们改用新字段。

如果两者都需要用到,则先用 Move Field(搬移字段) ,再用 Move Method(搬移函数)

1551665219564

提炼类

一个类承担过多的责任会导致臃肿不堪,这个时候可以使用 Extract Class(提炼类) 将相关的字段和函数从旧类搬移到新类。从而使一部分责任分离出去。

1551665252354

将类内联化

如果一个类变得“不负责任”(几乎不干任何事情或者不对任何事情负责也没有计划往这个类添加任何职责),则可以使用 Inline Class(将类内联化) 将它容易另一个类。

1551665271997

隐藏委托关系

为了保持对象的封装性,应该避免对外暴露过多的细节。如果一个类使用了另一个类,可以使用 Hide Delegate(隐藏委托关系) 将这种关系隐藏起来。

1551665323161

移除中间人

封装受托对象也是要付出代价的:每当客户要使用受托类的新特性的时候,就必须在服务端添加一个简单的委托函数,随着受托类特性越来越多,这个过程会让你痛苦不堪。服务类完全变成了一个“中间人”,此时应该让客户直接调用次受托类。

有时候隐藏委托类会导致拥有者的接口经常变换,这个时候要用 Remove Middle Man(移除中间人)

1551665345853

引入外加函数

当我们不能访问某个类的源码,却又想把其他职责移进这个不可修改的类时,如果想加入的只是一两个函数,可以考虑使用 Introduct Foreign Method(引入外加函数)

外加函数终归是权宜之计,如果有可能,仍然应该讲这些函数版一到他们的理想家园。

1
2
3
4
5
6
7
8
class Report {
// ...
void sendReport() {
Date nextDay = new Date(previousEnd.getYear(),
previousEnd.getMonth(), previousEnd.getDate() + 1);
// ...
}
}
1
2
3
4
5
6
7
8
9
10
class Report {
// ...
void sendReport() {
Date newStart = nextDay(previousEnd);
// ...
}
private static Date nextDay(Date arg) {
return new Date(arg.getYear(), arg.getMonth(), arg.getDate() + 1);
}
}

引入本地扩展

如果不止一两个函数,就使用 Introduct Local Extension(引入本地扩展)

可以建立一个新类,使它包含这些额外函数,让这个扩展品成为源类的子类或包装类

1551665377323

arthinking wechat
欢迎关注itzhai公众号