写点什么

「架构师训练营第 1 期」第二周作业

用户头像
张国荣
关注
发布于: 2020 年 09 月 26 日

作业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

由于接口实现中,重复的方法签名只会被实现一次,所以可以通过新增一个接口并进行新的组合来实现。

然后对外分别提供应用接口、系统接口、新接口,这样其他方法是不可见的。

下图为优化后类图



用户头像

张国荣

关注

还未添加个人签名 2018.06.26 加入

还未添加个人简介

评论

发布
暂无评论
「架构师训练营第1期」第二周作业