设计模式(7)——SOLID原则之接口隔离原则
设计模式(7)——SOLID原则之接口隔离原则
- 概念
- 示例
- 总结
概念
客户端不应被强迫依赖于其不使用的方法。这句话的意思是指尽量缩小接口的范围,使得客户端的类不必实现其不需要的行为。
根据接口隔离原则,你必须将“臃肿”的方法拆分为多个颗粒度更小的具体方法。客户端必须仅实现其实际需要的方法。否则,对于“臃肿”接口的修改可能会导致程序出错,即使客户端根本没有使用修改后的方法。
示例
阿里云,华为云等云服务厂商都有自己不同的sdk实现,当同时使用多家云服务厂商时,就需要分别调用不同的sdk。假如我们现在想要封装出一套云服务厂商通用接口,可以定义接口CloudProvider
,不同的云厂商分别实现即可。
但是CloudProvider
接口定义的太过宽泛,如果某些云服务厂商没有提供部分功能,那就不得不插入一些桩代码或者空实现的方法。比如华为云不支持获取CDN地址与操作云服务的方法,那就只能实现空方法,这不是最优的解决方案。
分析CloudProvider接口,主要包含三部分功能:云服务器接口、云存储接口、CDN接口。如果将CloudProvider接口的职责按上述功能粒度进一步划分,改写成云服务接口CloudServerProvider、CDN接口CloudCDNProvider和云存储接口CloudStorageProvider。不同的云厂商只需要实现已支持功能的接口即可。