写点什么

架构师训练营第二周作业

用户头像
J
关注
发布于: 2020 年 12 月 05 日

2.8 第二周课后练习


  1. Q: 请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?

A: 依赖倒置原则(Dependency Inversion Principle, DIP)。

  1. High-level modules should not depend on low-level modules. Both should depend on abstractions.

  2. 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!”。在好莱坞,演员把简历递交给演艺公司后就只有回家等待,由演艺公司(高层)对整个娱乐项的完全控制,演员(低层)只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。所以两者有异曲同工之妙。


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


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


A: 优化后的类图如下,思路是接口隔离原则,根据使用方的分类,将原来的 Cache 的接口分解成两个接口ICacheICacheBuilder,分别用于普通应用程序,以及系统应用。



用户头像

J

关注

还未添加个人签名 2015.06.24 加入

还未添加个人简介

评论

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