架构师训练营 Week2 作业
1.请描述什么是依赖倒置原则,为什么有时候依赖倒置原则又被称为好莱坞原则?
依赖倒置原则:上层模块不应该依赖底层模块,它们都应该依赖于抽象。比如在SPI实现,调用者属于高层,被调用则属于底层,按照一般逻辑,高层调用底层,需要底层先实现功能,比如实现一个函数接口,高层再调用这个接口;但这样的方式依赖性太强,高层必须依赖底层,开发效率低下,没有统一规范约定。所以在实际中往往是抽象约定接口方式设计和开发,高层不必依赖底层,而是依赖抽象的接口,高层实现调用已经实现接口的底层类,底层实现约定好的接口。思维方式的转变,就是依赖倒置的原本意思。
为什么被称为好莱坞原则?
A.来源好莱坞的经典语句:Don't call me. I will call you
B.因为依赖倒置原则在框架设计中经常被使用,如tomcat、spring等框架,这些框架和应用开发者开发的应用关系存在依赖倒置关系:应用中代码不需要调用框架,框架会自动调用应用,如tomcat中运行springboot应用一般。tomcat属于高层,sprintboot应用属于底层,约定好抽象接口,进行开发。
2.请用接口隔离原则优化 Cache 类的设计,画出优化后的类图。
提示:cache 实现类中有四个方法,其中 put get delete 方法是需要暴露给应用程序的,rebuild 方法是需要暴露给系统进行远程调用的。如果将 rebuild 暴露给应用程序,应用程序可能会错误调用 rebuild 方法,导致 cache 服务失效。按照接口隔离原则:不应该强迫客户程序依赖它们不需要的方法。也就是说,应该使 cache 类实现两个接口,一个接口包含 get put delete 暴露给应用程序,一个接口包含 rebuild 暴露给系统远程调用。从而实现接口隔离,使应用程序看不到 rebuild 方法。
优化类图如下:
代码调用如下:
1.Cache实现AppCache和SystemCache接口。
2.在给不同使用者对象调用时,声明相应的接口类,通过接口类来屏蔽其他不相干的方法
版权声明: 本文为 InfoQ 作者【lggl】的原创文章。
原文链接:【http://xie.infoq.cn/article/c4b9f31987de1511731c0fec9】。
本文遵守【CC BY-NC】协议,转载请保留原文出处及本版权声明。
评论