架构师训练营第 1 期 -Week2 - 课后练习
作业一:
1. 请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
解答:
依赖倒置原则: Dependency Inversion Principle(DIP)是说:高层模块不依赖低层模块,低层模块不依赖高层模块,而是都依赖于抽象。抽象不能依赖实现,而是实现依赖抽象。
依赖倒置原则常用于软件框架设计,是框架设计的核心原则。这里框架就是高层模块,框架定义自己的接口(也就是抽象,这些接口是高层模块定义的),根据抽象去设计和开发框架。使用框架去开发业务逻辑,这里就是低层模块,低层模块实现框架定义的接口,高层模块就可以去调用低层模块的代码。这就是高层模块和低层模块,都依赖于抽象。
依赖倒置原则,改变了软件开发的依赖关系。在一般的开发流程是:高层模块依赖低层模块,一般是先开发好低层模块,在开发调用低层模块的高层模块。低层模块的重用性高,而高层模块的重用性低。但是依赖倒置原则时,先在高层模块定义好接口,然后高层模块进行设计和开发,同时低层模块也可以去实现这个接口。这样高层模块的重用性变高。依赖倒置原则倒置了依赖关系,将高层模块依赖低层模块,变成了低层模块依赖高层模块,改变了开发的顺序。
依赖倒置原则中,高层模块不依赖低层模块,而是依赖高层模块定义的抽象,低层模块实现这个抽象,高层模块根据这个抽象,就可以调用低层模块。而低层模块只需要实现这个抽象,不需要调用高层模块的代码, 就像好莱坞规则说的:Dont't call me, I'll call you(低层模块只需要实现抽象,高层模块就可以 call 低层模块)。所以说依赖倒置原则又被称为好莱坞原则
依赖倒置原则,是框架设计的指导原则,是框架设计的核心技巧。它使架构师不纠结与程序设计的细节之中。架构师可以通过框架,框清代码,实现架构的落地
2. 请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
解答: 优化后的类图如下:
抽象出两个接口:IApplicationCache 和,ISystemCache。Cache 实现这两个接口。通过两个适配器 ApplicationCacheAdapter、SystemCacheAdapter 来适配两种不同的场景(应用程序调用,系统调用)。两个适配器分别实现不同的接口,并通过组合 Cache 的方式来复用 Cache 的代码,适配不同的场景。
评论