版权声明
- 原文链接: https://zhuanlan.zhihu.com/p/682910525
- 原文作者: canonical - canonical_entropy@163.com
- 转载编者: flytreeleft - flytreeleft@crazydan.org
- 版权声明: 本转载文章的权益归原文作者所有,再次转载请注明原文来源及原文作者,并声明原文版权!
在 如何评价一种框架技术的好坏 一文中, 我提到一个概念,框架中立性(Framework Agnostic),并指出, 最理想的框架,应该是在开发业务代码时完全意识不到它存在的框架。 有些人读后提出疑问:就目前而言,没有任何业务开发完全独立于框架,这个概念有什么意义? 讨论群中有热心同学回复到:
软件开发依赖框架是因为要用到框架提供的输入输出,事件回调,依赖注入,外部数据读写,上下文等, 大多数都是程序运行依赖的副作用。如果做一个业务的时候,按照一个库去设计, 将所有的副作用都显式的声明为接口和上下文对象,有个中间层去衔接框架和设计出来的业务库, 那么这个业务库就可以不依赖框架了。
有人试图反驳:那这种情况不还是制定一种内部标准,既然如此,我用 spring 的标准又有什么问题? 关于这个问题的解答有点微妙,需要有一定的精细概念的分辨能力才能够理解,在这里我简单做一些概念辨析。