重构读书笔记-7_7-Introduce_Foreign_Method

重构第七章

7.Introduce Foreign Method(引用外加函数)

你所使用的server class需要一个额外函数,但你无法修改这个class。在client class中建立一个函数,并以一个server class实体作为第一引数(argument)。

Example:

Date newStart = new Date(previousEnd.getYear(),previousEnd.getMonth(),previousEnd.getDate()+1);

Analyse:

首先,讲解中的server、client并不是真正的服务端和客户端,他只是说明,两个之间的关系如同服务端和客户端,彼此调用,有互相不知道具体的实现。
你作为一个客端的开发人员,你可能不清楚服务端的实现细节,并且,你可能没有服务端的源码,不能对服务端进行任意的修改,添加你想要的方法。这个时候是使用Introduce Foreign Method(引用外加函数)最好的时机。

EX中需要跨过一个收费周期,可以将赋值语句左侧的代码提炼到一个独立函数中,这个函数就是Date class的一个外加函数。

End:

Date newStart = nextDay(previousEnd);

private static Date nextDay(Date arg) {
    return newDate(arg.getYear(), arg.getMonth(), arg.getDate() + 1);
}

Conclusion:

Introduce Foreign Method(引用外加函数)我认为是一种并不是很优美,同时有些无可奈何的重构方法。真正结构优秀的代码,应该将每个类 的职责单一化,该是哪个类应该提供的,就应该哪个类提供。
所以使用Introduce Foreign Method方法的时候,需要看清前提。如果可以在服务端源码中直接添加实现,这是最好的解决方法。

注意

重构必须在有单元测试的情况下,保证之前的功能修改后不收影响。切记!!!

你可能感兴趣的:(重构读书笔记-7_7-Introduce_Foreign_Method)