依赖倒置和接口隔离原则
什么是依赖倒置原则
高层模块不能依赖低层模块,抽象不能依赖于实现。简单理解为面向接口编程、面向抽象编程。在做架构设计时先设计好接口,做好抽象,基于抽象,高层模块负责模块接口设计和抽象设计,低层模块按照高层模块设计进行实现。高层决定低层。
为什么有时候依赖倒置原则又被称为好莱坞原则
Don't call us, we will call you。这句话阐述了框架与service之间的高低层关系,即框架为高层,service为低层,框架来调用service,service无需调用框架。
模板方法模式体现了好莱坞原则,所有组件调用都是被动的,所有组件初始化和调用都由容器负责。
用接口隔离原则设计 Cache 类图
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
优化后类图如下:
版权声明: 本文为 InfoQ 作者【Mars】的原创文章。
原文链接:【http://xie.infoq.cn/article/1963f07fe22a3e0e1257e16f9】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论