「架构师训练营第 1 期」第二周作业
作业1:
1. 请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则(Dependence Inversion Principle)是程序要依赖于抽象接口,不要依赖于具体实现。简单的说就是要求对抽象进行编程,不要对实现进行编程,这样就降低了客户与实现模块间的耦合。
因为遵循依赖倒置原则,程序的主流程是抽象的,具体的实现由容器管理,主流程按需引入具体实现,而不是硬编码在主流程中。
好莱坞原则简称Don‘t call us, we‘ll call you,在好莱坞,把简历递交给演艺公司后就只有回家等待。由演艺公司对整个娱乐项的完全控制,演员只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。这和我们的依赖倒置原则不谋而合,所有依赖倒置原则也就叫好莱坞原则。
作业2
2. 请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
思路:既然put get delete是提供给应用程序的而rebuild是提供给系统调用的,那么接口设计就应该区分应用程序接口,系统程序接口。
应用接口:put、get、delete
系统接口:rebuild
然后Cache实现应用接口+系统接口。
一点扩展:显示当中可能会有这种场景,假设我们新增加一个调用方,需要调用get、rebuild那怎么办?
我们可以新增加一个新接口。
新接口:get、rebuild
由于接口实现中,重复的方法签名只会被实现一次,所以可以通过新增一个接口并进行新的组合来实现。
然后对外分别提供应用接口、系统接口、新接口,这样其他方法是不可见的。
下图为优化后类图
评论