第二周 框架设计 作业一
1、请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则
高层模块不要依赖低层模块,高层模块和低层模块应该通过抽象来互相依赖。除此之外,抽象不要依赖具体实现细节,具体实现细节依赖抽象
例如类 C1、C2、C3 都有相同的属性和方法,都有可能被类 H 调用(高层调用低层)。如果 H 类的实例直接调用这三个类,那么 H 就和 C1、C2、C3 发生了耦合。 如果把这三个类抽取出一个接口 I,类 H 调用 I(面向接口编程),H 就依赖于接口,C1、C2、C3 也依赖于接口。在这种情况下,类与类之间的耦合降低了,不依赖具体类而是依赖于接口。
好莱坞原则
don't call me, I will call you
好莱坞原则的场景是演员 N1、N2……都希望和电影公司 C 合作,因此他们将联系方式给了 C,当 C 需要的时候就会打电话通知其中的 Nx、Ny……过来。 这里的电影公司 C 是高层,演员 N1、N2……是低层。低层演员是不知道高层公司何时需要他们的,因此只能是高层通知低层,而不是低层询问高层。
依赖倒置原则和好莱坞原则都是通过高层调用低层的方式实现,从这方面来看依赖倒置原则可以被称为好莱坞原则。
2、请用接口隔离原则优化 Cache 类的设计,画出优化后的类图
cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。
如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。
按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。
也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法
优化后的类图如下:
版权声明: 本文为 InfoQ 作者【应鹏】的原创文章。
原文链接:【http://xie.infoq.cn/article/82e466876b223b79e56f4a238】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论