架构师训练营第二周作业
2.8 第二周课后练习
Q: 请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
A: 依赖倒置原则(Dependency Inversion Principle, DIP)。
High-level modules should not depend on low-level modules. Both should depend on abstractions.
Abstractions should not depend on details. Details should depend on abstractions.
According to this principle the way of designing a class structure is to start from high level modules to the low level modules:
High Level Classes --> Abstraction Layer --> Low Level Classes
DIP 的核心是高层不依赖于底层,而是依赖于抽象层,抽象的具体化是接口。并且,这种抽象和接口必须属于高层,即设计和定义是由高层决定,而不是底层。
好莱坞原则,是指“Don't call us, we will call you!”。在好莱坞,演员把简历递交给演艺公司后就只有回家等待,由演艺公司(高层)对整个娱乐项的完全控制,演员(低层)只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。所以两者有异曲同工之妙。
Q: 请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
A: 优化后的类图如下,思路是接口隔离原则,根据使用方的分类,将原来的 Cache 的接口分解成两个接口
ICache
和ICacheBuilder
,分别用于普通应用程序,以及系统应用。
评论