【架构师训练营】第二周作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则(Dependence Inversion Principle DIP):
1>高层模块不应该依赖低层模块,而是大家都依赖于抽象。
2>抽象不应该依赖实现,而是实现应该依赖抽象。
3>依赖倒置的中心思想是面向接口编程。
依赖倒置原则是一种应该养成的编程习惯,它要求面对接口编程。
好莱坞原则(Hollywood Principle):别打电话给我们,有事我会打电话给你。
好莱坞原则是用在系统的高层组件与底层组件之间。高层组件不应该直接调用底层组件,而是从容器获取。
例子:假设qq在线聊天,有聊天框和表情选择框,那么,打开聊天框,然后打开表情框,选择表情——这个过程不应该在聊天框的代码里出现(或者说,聊天框不应该参与直接调用表情框),而是应该聊天框告诉qq容器:我要调用A,虽然我不知道那是什么,然后容器提供A(表情框组件)。好处是假如之后腾讯更新了更好的表情框,然后由容器控制生命周期,而聊天框则不参与。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
Spring框架当中,依赖倒置原则使用IOC(控制翻转)来实现依赖倒置原则,具体采用的方法也就是依赖注入。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
作业三提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
优化后类图:
评论