整洁架构SOLID-接口隔离原则(ISP)
创始人
2025-01-11 04:02:32
0

文章目录

  • 定义
  • ISP与编程语言
  • ISP与软件架构
  • 小结

定义

在这里插入图片描述
在上图中有多个用户需要操作OPS类。现在,我们假设这里的User1只需要使用op1,User2只需要使用op2,User3只需要使用op3。

在这种情况下,如果OPS类是用Java编程语言编写的,那么很明显,User1虽然不需要调用op2、op3,但在源代码层次上也与它们形成依赖关系。这种依赖意味着我们对OPS代码中op2所做的任何修改,即使不会影响到User1的功能,也会导致它需要被重新编译和部署。

这个问题可以通过将不同的操作隔离成接口来解决,具体如下图所示:
在这里插入图片描述

同样,我们也假设这个例子是用Java这种静态类型语言来实现的,那么现在User1的源代码会依赖于U1Ops和op1,但不会依赖于OPS。这样一来,我们之后对OPS做的修改只要不影响到User1的功能,就不需要重新编译和部署User1了。

ISP与编程语言

很明显,上述例子很大程度上也依赖于我们所采用的编程语言。对于Java这样的静态类型语言来说,它们需要程序员显式地import、use或者include其实现功能所需要的源代码。而正是这些语句带来了源代码之间的依赖关系,这也就导致了某些模块需要被重新编译和重新部署。

而对于Ruby和Python这样的动态类型语言来说,源代码中就不存在这样的声明,它们所用对象的类型会在运行时被推演出来,所以也就不存在强制重新编译和重新部署的必要性。这就是动态类型语言要比静态类型语言更灵活、耦合度更松的原因。

如果认为ISP只是一个与编程语言的选择紧密相关的设计原则,而非软件架构问题,这就错了。

ISP与软件架构

回顾一下ISP最初的成因:在一般情况下,任何层次的软件设计如果依赖于不需要的东西,都会是有害的。从源代码层次来说,这样的依赖关系会导致不必要的重新编译和重新部署,对更高层次的软件架构设计来说,问题也是类似的。

例如,我们假设某位软件架构师在设计系统S时,想要在该系统中引入某个框架F。这时候,假设框架F的作者又将其捆绑在一个特定的数据库D上,那么就形成了S依赖于F,F又依赖于D的关系,如下图所示:
在这里插入图片描述

在这种情况下,如果D中包含了F不需要的功能,那么这些功能同样也会是S不需要的。而我们对D中这些功能的修改将会导致F需要被重新部署,后者又会导致S的重新部署。更糟糕的是,D中一个无关功能的错误也可能会导致F和S运行出错。

小结

ISP设计原则告诉我们:任何层次的软件设计如果依赖了它并不需要的东西,就会带来意料之外的麻烦。

参考内容来源于:《架构整洁之道》

相关内容

热门资讯

第三分钟有挂!插件脚本模板(辅... 第三分钟有挂!插件脚本模板(辅助挂)揭秘教程(果然存在有挂)1)插件脚本模板辅助挂:进一步探索插件脚...
九分钟了解!透视辅助器(免费)... 1、九分钟了解!透视辅助器(免费)(辅助挂)切实真的是有挂(详细辅助教程)(UU poker、透视辅...
重大来袭!八闽掌上辅助软件(辅... 重大来袭!八闽掌上辅助软件(辅助挂)往昔真的有挂(详细辅助透明教程);人气非常高,ai更新快且高清可...
2分钟辅助器!灯笼众娱脚本(辅... 2分钟辅助器!灯笼众娱脚本(辅助挂)微扑克教程(原来是真的有挂)灯笼众娱脚本辅助器中分为三种模型:灯...
第四分钟了解!相约十三水辅助开... 第四分钟了解!相约十三水辅助开挂教程(辅助挂)一贯是真的有挂(详细辅助工具)准备好在相约十三水辅助开...
玩家交流!蜀门手游辅助免费脚本... 玩家交流!蜀门手游辅助免费脚本(辅助挂)最初是真的有挂(详细辅助2025教程);1分钟了解详细教程(...
第7分钟辅助挂!微信微乐游戏辅... 第7分钟辅助挂!微信微乐游戏辅助脚本(辅助挂)大神讲解(素来真的有挂)微信微乐游戏辅助脚本辅助器中分...
第五分钟了解!新金龙辅助(辅助... 1、第五分钟了解!新金龙辅助(辅助挂)好像有挂(详细辅助教程)。2、新金龙辅助透视辅助简单,新金龙辅...
必备攻略!蜀门手游辅助免费脚本... 必备攻略!蜀门手游辅助免费脚本(辅助挂)最初真的是有挂(详细辅助存在挂教程);蜀门手游辅助免费脚本软...
3分钟辅助!八大碗辅助器(辅助... 3分钟辅助!八大碗辅助器(辅助挂)第三方教程(竟然是有挂)1)八大碗辅助器辅助挂:进一步探索八大碗辅...