设计模式就该这样学:基于经典框架源码和真实业务场景
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

3.4 接口隔离原则

3.4.1 接口隔离原则的定义

接口隔离原则(Interface Segregation Principle,ISP)指用多个专门的接口,而不使用单一的总接口,客户端不应该依赖它不需要的接口。这个原则指导我们在设计接口时,应当注意以下几点。

(1)一个类对另一个类的依赖应该建立在最小接口上。

(2)建立单一接口,不要建立庞大臃肿的接口。

(3)尽量细化接口,接口中的方法尽量少(不是越少越好,一定要适度)。

接口隔离原则符合“高聚合、低耦合”的设计思想,使得类具有很好的可读性、可扩展性和可维护性。在设计接口的时候,要多花时间思考,要考虑业务模型,包括还要对以后可能发生变更的地方做一些预判。所以,在实际开发中,我们对抽象、业务模型的理解是非常重要的。

3.4.2 使用接口隔离原则解决实际问题

我们来写一个动物行为的抽象。

IAnimal接口的代码如下。

img
img

Bird类实现的代码如下。

img

Dog类实现的代码如下。

img

由上面代码可以看出,Bird类的swim()方法可能只能空着,Dog类的fly()方法显然是不可能的。这时候,我们针对不同动物的行为来设计不同的接口,分别设计IEatAnimal、IFlyAnimal和ISwimAnimal接口。

IEatAnimal接口的代码如下。

img

IFlyAnimal接口的代码如下。

img

ISwimAnimal接口的代码如下。

img

Dog只实现IEatAnimal和ISwimAnimal接口。

img
img

我们来看两种类图的对比,如下图所示,还是非常清晰明了的。

img