架构师训练营——Week2 作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则(Dependency Inversion Principle):A.高层次的模块不应该依赖于低层次的模块,他们都应该依赖于抽象。B.抽象不应该依赖于具体实现,具体实现应该依赖于抽象。
好莱坞原则(Hollywood Principle):别打电话给我们,有事我会打电话给你。
好莱坞原则类似于依赖倒置原则的第一条,低层不应该调用高层,而应该实现高层定义的抽象接口,高层通过接口来调用低层。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
Spring 框架中是通过依赖注入来实现依赖倒置原则的。spring 中 bean 的依赖不需要自己去实例化,Spring 框架会帮忙注入到 bean 中。
Servlet 规范中定义的 Servlet 接口,就是 Servlet 容器(高层)和具体的 Servlet (低层)公共依赖的接口。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
作业三提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
可以修改为如下类图所示:
Cache 类同时实现 GenericCache 接口和 Rebuildable 接口,满足 Cache 类的功能需求,但是在将 Cache 实例提供给应用程序的时候,只因该暴露为 GenericCache 接口的实例,从而保护 rebuild 方法不被看到;Cache 实例提供给远程系统调用的时候只需提供 Rebuildable 接口接口。
版权声明: 本文为 InfoQ 作者【Shawn】的原创文章。
原文链接:【http://xie.infoq.cn/article/081246c6f3f1de2e2cf7691aa】。未经作者许可,禁止转载。
评论