架构师训练营第 2 周课后练习
题目描述
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
解答
1.依赖倒置原则就是高层模块不依赖低层模块,它们都依赖于抽象。抽象不依赖具体实现细节,具体实现细节依赖于抽象。在调用链上,调用者属于高层,被调用者属于低层。在平时的业务代码开发中,高层模块依赖低层模块没有任务问题。实际上,这条原则主要用来指导框架层面的开发。举个例子,比如 spring MVC,从调用的角度看,请求先到了 DispatcherServlet,再由 DispatcherServlet 调用业务处理的 Controller。它们都依赖框架定义的注解,这些注解就是一种抽象。
好莱坞原则是 don‘t call us, we‘ll call you。好莱坞类比框架,演员类比业务代码。好莱坞和框架拥有主导和控制权。演员和业务代码只要做好自己的事,然后等待被启用/调用。
2.
评论