写点什么

2 期架构师训练营 - 框架设计

用户头像
Vicente
关注
发布于: 2020 年 11 月 01 日
  1. 请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?

依赖倒置原则(DIP,Dependency Inversion Principle),又称为好莱坞原则。在好莱坞,低层的演员不能自己决定参演什么电影,高层的公司会根据电影等需要和演员的匹配度去主动去通知演员,"Don't call us, we will call you",这个和依赖倒置原则的原理是一样的,所以依赖倒置原则也叫做好莱坞原则。


依赖倒置主要有以下几个要点:

1)高层模块/组件不依赖底层模块/组件,二者应该依赖于抽象;

2)抽象不依赖于具体实现,实现依赖于抽象。


在具体实践中就是要求我们面向接口编程,不应该是先实现来低层组件的逻辑,再来写高层逻辑和调用,而是应该反过来,高层组件来定义接口和规范,低层组件来实现。


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

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


方法一:

抽象两个接口和两个实现,原来的 Cache 不改动,添加 @Deprecated 注解标识为不建议使用。

方法二:基于原来的 Cache 类,通过适配器的方式来创建两个不同的实现类。


用户头像

Vicente

关注

还未添加个人签名 2008.09.18 加入

功不唐捐,玉汝于成

评论

发布
暂无评论
2 期架构师训练营 - 框架设计