架构师训练营:第二周 作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则:
1、高层模块不应该依赖低层模块,二者都应该依赖抽象 。
2、抽象不应该依赖具体实现,具体实现应该依赖抽象。
高模块和低模块是指什么?
是指在调用链上,调用者属于高层,被调用者属于低层。
MVC架构:常用的使用方式Controller-->Service-->Dao;Controller对应Service来说就是高模块,Service对于Dao来说也是高模块。
这种情况如何去解决高层模块不应该依赖低层模块?
依赖倒置原则中,除了具体实现要依赖抽象,最重要的是,抽象是属于谁的抽象。即:Service的接口定义由编写Controller的开发者定义的,然后由编写Service实现的人来实现接口,则就符合依赖倒置原则。
为什么有时候依赖倒置原则又被称为好莱坞原则:
好莱坞原则简称Don‘t call us, we‘ll call you,科普下在好莱坞,把简历递交给演艺公司后就只有回家等待。由演艺公司对整个娱乐项的完全控制,演员只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。这和我们的依赖倒置原则不谋而合,所有依赖倒置原则也就叫好莱坞原则。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
Spring Ioc 就是一个实现依赖倒置原则的。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
作业三提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
通过ProxyCache中定义一个子类实现Cache接口定义,暴露给App(应用程序调用)
通过ProxyCache中定义一个子类实现CacheBuilder接口定义,暴露给Frame(框架调用)
评论