设计原则之依赖倒置与接口隔离

用户头像
L001
关注
发布于: 2020 年 06 月 17 日

什么是依赖倒置原则

概念:高层模块不依赖于低层模块。高层模块和低层模块应该通过抽象来互相依赖。除此之外,抽象不依赖具体实现细节,具体实现细节依赖抽象。

解释:调用者属于高层,被调用者属于低层。两者都依赖同一个抽象去实现,如Servlet规范。

为什么有时候依赖倒置原则又被称为好莱坞原则

好莱坞原则:别打电话给我们,有事我会打电话给你。大意是有演出等需求的时候,演出公司看那个角色适合哪个演员,并主动找响应的演员来演出,而演员不要自己主动打电话给公司推荐自己。

好莱坞原则通用在系统的高层组件与底层组件之间调用关系。高层组件不应该直接调用底层组件,而是从容器获取。比如在Spring MVC开发中,controler层不要直接new一个service实现类,而是从spring容器中获取自己需要的service。

描述一个框架,是如何实现依赖倒置原则的

在Spring MVC中,类的组织方式通常是用依赖注入的方式实现的。在启动系统的时候,Spring会把类创建好,并通过参数注释,构造注入的方式实现类之间的解耦。

1. 把类的元信息配置在属性文件中,
2. 读取配置文件中的信息,并保存在容器中,如Map<Sting,Objict> classInfo
3. 读取配置文件,通过反射的方式实例化一个class对象
4. 把依赖的类信息注入到调用类中


接口隔离原则应用场景

用接口隔离原则优化 Cache 类的设计,画出优化后的类图。

cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,
rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,
应用程序可能会错误调用rebuild 方法,导致 cache 服务失效。
按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,
一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。
从而实现接口隔离,使应用程序看不到 rebuild 方法。



类图:



用户头像

L001

关注

还未添加个人签名 2018.04.28 加入

还未添加个人简介

评论

发布
暂无评论
设计原则之依赖倒置与接口隔离