架构师训练营 Week02 作业

用户头像
IT老兵重开始
关注
发布于: 2020 年 09 月 27 日

作业1、请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?

依赖倒置原则(Dependence Inversion Principle)是面向对象设计的一种基本设计原则,从原文定义看:“High level modules should not depend upon low level modules. Both should depend upon abstractions. Abstractions should not depend upon details. Details should depend upon abstractions。”其要点主要两个:

  • 高层模块不应该依赖低层模块,二者都应该依赖抽象。

  • 抽象不应该依赖具体实现,具体实现应该依赖抽象。

这个刚一看有点蒙圈,因从大学上编程课学到的是高层模块是依赖低层模块,例如工作中代码也是 经常使用工具类,just like fastjson,那这怎么理解呢?

回顾我们在用java写代码时,写最多的就是class、interface,所有模块之间的调用都是接口调用,我在想如果用class和interface来理解DIP会是怎么样呢?又想了想类和接口的定义。突然有一种顿悟的感觉:DIP不就是面向对象的核心面向接口编程的一种说法吗?我想把这两句话改为自己理解的一句话:

DIP:高层模块不应依赖低层模块的实现,而是依赖底层模块的接口,白话(高层模块应该调用低层模块的接口,不能调用低层模块的实现)。

著名的好莱坞原则是:don‘t call us, we‘ll call you。在好莱坞,演员把简历递交给演艺公司后就只有回家等待,由演艺公司(高层)对整个娱乐项的完全控制,演员(低层)只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。【来自百度百科】,好莱坞原则和依赖倒置原则相似,所以DIP有时候也叫做好莱坞原则,跨界同理。



作业2 请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。



  • 提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。



优化后的类图如下:





发布于: 2020 年 09 月 27 日 阅读数: 26
用户头像

IT老兵重开始

关注

IT老兵 2018.04.25 加入

还未添加个人简介

评论

发布
暂无评论
架构师训练营Week02作业