架构师训练营 Week 02 作业
一、什么是依赖倒置原则
DIP, Dependency Inversion Principle
依赖倒置是一种解耦合的方式。首先通过对底层实现进行抽象,得到接口;供上层使用,使上层不必依赖底层模块;然后底层再实现抽象接口的细节,从而实现工作流程的预定义。
依赖倒置又被称为好莱坞原则,“不要给打电话,我们会给你打电话(don‘t call us, we‘ll call you)”。在好莱坞,把简历递交给演艺公司后就只有回家等待。由演艺公司对整个娱乐项的完全控制,演员只能被动式的接受公司的差使,在需要的环节中,完成自己的演出。
二、MFC框架中的依赖倒置
MFC(Microsoft Foundation Classes),是以C++类的形式封装了Windows API的类库,并且包含一个应用程序框架。
在MFC中,预定义了多文档、单文档等GUI程序框架。用户通过实现自己得文档类和视图类,来实现功能。在用户编码时,不必关心各个模块是如果串联起来的,只要专注自己的业务。然后通过宏定义注册相应的模块,即可实现框架的配置。
三、接口隔离原则实践
cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。
改写cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
评论