架构师训练营 第二周作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
设计模式依赖倒置原则:
高层模块不应该依赖低层模块,两者都应该依赖抽象
抽象不应该依赖细节
细节应该依赖抽象
好莱坞原则:别调用我们,我们会调用你
依赖倒置原则教我们尽量避免使用具体类,而多使用抽象。
而好莱坞原则是用在创建框架或组件上的一种技巧,好让低层组件能够被挂钩进计算中,而且又不会让高层组件依赖低层组件。两这个的目标都是在于解耦,但是依赖倒置原则更加注重如何在设计中避免依赖。
好莱坞原则教我们一个技巧,创建一个有弹性的设计,允许低层结构能够互相操作,而又防止其他类太过依赖它们。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
Spring 的核心 IOC,其实本质上就是一个容器,而这个容器里面都是管理的一个个 JAVA 类,Spring 是依赖倒置思想的落地实现是因为 Spring 的核心,即 IOC,虽然 Spring 的设计理念和依赖倒置思想没有直接关系,但因为有了依赖倒置思想的落地实现过程才设计了 Spring,其实真正和依赖倒置思想面向接口解耦这一逻辑直接相关的是现在 Spring 体系中常用的分层逻辑。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
作业三提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
评论