架构师训练营第二周作业
作业一:
请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则(DIP)是指高层模块不应该依赖低层模块,他们应该通过抽象相互依赖,抽象不应该依赖实现细节,实现细节应该依赖于抽象。
好莱坞原则是指:不需要联系我(开发者调用框架),我会主动联系你(框架调用开发者代码);即应用程序的流程控制由程序员调用依赖的框架反转为了由框架调用程序员编写的类和方法,控制流程上发生了倒置。
作业二:
请描述一个你熟悉的框架,是如何实现依赖倒置原则的。
举例:ASP.NET Core是一个Web开发框架,对于客户端的HTTP请求,按照调用关系划分,应用程序开发者编写的Web服务作为低层模块会被作为高层模块的Web开发框架调用,但实际是框架定义了一套管道(Pipline)的抽象,Web服务实现这个抽象,框架和Web服务并不直接相互依赖,他们共同依赖于管道的抽象。
作业三:
请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
作业三提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
评论