架构与框架的联系与区别

1、什么是架构?

以下是对业界对架构的一些定义:

  • 在ISO/IEC 42010: 2011中,定义为:一个系统在其所处环境中所具备的各种基本概念和属性,具体体现为其所包含的各个元素,元素之间的关系以及架构的设计和演进原则。
  • 架构是针对某种特定目标系统的具有体系性的、普遍性的问题而提供的通用解决方案。
  • 架构往往是对复杂系统的一种共性的体系抽象。
    看了以上定义,感觉还是难搞懂到底什么是架构,个人认为下面这个聚焦到信息系统构建目的定义更容易理解:

架构让我们能够正确、合理地理解、设计和构建复杂的信息系统。

2、什么是框架?

框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。是一个基本概念上的结构,用于去解决或者处理复杂的问题。

上面这个感觉其实很好理解,强调了框架的支撑性。

3、架构与框架的联系与区别

架构是一个动词,是一个方法论,包含一系列活动过程和步骤。框架是一个名词,是一个客观的存在。框架的搭建需架构方法论的指导。

下面是从IT这个领域对架构与框架之间区别的理解[1]:

框架就是软件,架构不是软件。

框架一种特殊的软件,它不能提供完整的解决方案,而是为构建解决方案提供良好的基础,框架是半成品,框架中的服务被应用直接调用,框架中的扩展点是供应用开发人员定制的“可变化点”。

架构不是软件,而是关于软件如何设计的策略,架构决策体现在软件系统中。引入软件架构之后,整个开发过程变成了“分两步走”,先做架构设计,再进行框架开发,架构决策会体现在框架之中。不能把软件代码说成是软件架构,因为软件架构是比具体代码高一个抽象层的概念。

框架和架构的出现,都是为了解决软件系统日益复杂所带来的困难而采取“分而治之”策略,先大局后局部,就出现了架构,先通用后专用,就出现了框架。下图很好揭示了这一点,架构是抽象解决方案,关注大局而忽略细节,而框架是通用半成品,还必须根据具体需求进一步定制开发才能变成应用系统。

参考:
1.架构与框架的联系与区别, https://zhuanlan.zhihu.com/p/86052051

你可能感兴趣的:(架构与框架的联系与区别)