架构师训练营 - 第二周命题作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则是指高层次的模块不依赖底层次的具体实现,而仅依赖底层次的接口,这样可以屏蔽底层实现的变化,保持高层次模块的稳定。具体开发中实现应该依赖抽象,抽象不能依赖实现。
梦想进入好莱坞的人们,你们不要找好莱坞。那怎么办呢?答案是,让好莱坞来找你!这就是著名的好莱坞原则。好莱坞就好像高层次模块,想进入好莱坞的人就像是低层次模块,你需要做好自己的工作,不要打扰好莱坞公司的运作(低层逻辑永远不要涉入高层的实现),好莱坞会主动找你。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
在我开发的项目中, 有一个消息发送服务MessageService,对不同类型的消息需要不同的实现。基于OOD的设计原则,MessageService作为高层模块包含了多个MessageSender的接口,通过spring框架自动注入不同的实现类。有新消息类型时可以开发新的MessageSender实现类。达到了高层依赖抽象,低层变化不影响高层的目标。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
评论