软件架构知识-总结1

本文介绍了系统、子系统、模块、组件、框架和架构等概念,强调了它们在软件开发中的不同角色。系统由关联的个体组成,遵循规则并产生新的能力;模块是从逻辑角度拆分的软件组织单位,而组件是物理角度的可重用单元。框架是组件规范和基础功能产品,而架构是软件的基础结构和设计准则。这些概念在不同维度定义了软件的构建和组织方式。
摘要由CSDN通过智能技术生成

系统与子系统

系统定义(维基百科):泛指由一群有关联的个体组成,根据某种规则运作,能完成个别元件不能单独 完成的工作的群体。其中3点关键内容:
1、关联:系统是由一群有关联的个体组成的,没有关联的个体堆在一起不能成为一个系统。
2、规则:系统内的个体需要按照指定的规则运作,而不是单个个体各自为政。规则规定了系统 内个
体分工和协作的方式。
3、能力:系统能力与个体能力有本质的差别,系统能力不是个体能力之和,而是产生了新的能 力。
其中按角度不同,子系统一般为更大系统的组成部分。比如QQ本身是一个大系统,包括小系统(聊天、群组等等)

模块与组件

模块定义(维基百科):是一套一致而互相有紧密关连的软件组织。它分别包含了程 序和数据结构两部分。现代软件开发往往利用模块作为合成的单位。模块的接口表 达了由该模块提供的功能和调用它时所需的元素。模块是可能分开被编写的单位。 这使它们可再用和允许人员同时协作、编写及研究不同的模块。
软件组件(维基百科):软件组件定义为自包含的、可编程的、可重用的、与语言无关的软件单元,软件组 件可以很容易被用于组装应用程序中。

模块和组件都是系统的组成部分,只是从不同的角度拆分系统而已。
从逻辑的角度来拆分系统后,得到的单元就是“模块”;
从物理的角度来拆分系统后,得到的单 元就是“组件”。
举例:论坛信息管理系统,这个系统从逻辑的角 度来拆分,可以分为“登录注册模块”“个人信息模块”“帖子模块”;从物理的角度来拆 分,可以拆分为 Nginx、Web 服务器、MySQL。

框架与架构

软件框架(维基百科):指的是为了实现某个业界标准或完成特定 基本任务的软件组件规范,也指为了实现某个软件组件规范时,提供规范所要求之 基础功能的软件产品。其中3点关键内容:

  1. 框架是组件规范:例如,MVC 就是一种最常见的开发规范,类似的还有 MVP、MVVM、 J2EE 等框架。
  2. 框架提供基础功能的产品:例如,Spring MVC 是 MVC 的开发框架,除了满足 MVC 的规 范,Spring 提供了很多基础功能来帮助我们实现功能,包括注解(@Controller 等)、Spring Security、Spring JPA 等很多基础功能。
    软件架构(维基百科):指软件系统的“基础结构”,创造这些基础结构的准则,以及对这些结构 的描述。
    举例:从业务逻辑的角度分解,“论坛信息管理系统”的架构是:
    在这里插入图片描述

从物理部署的角度分解,“论坛信息管理系统”的架构是:
在这里插入图片描述

从开发规范的角度分解,“论坛信息管理系统”可以采用标准的 MVC 框架来开发,因此架构又变成 了 MVC 架构:
在这里插入图片描述

这些“架构”,都是“论坛信息管理系统”正确的架构,只是从不同的角度来分解而已,这也是 IBM 的 RUP 将软件架构视图分为著名的“4+1 视图”的原因。

架构是顶层设计;框架是面向编程或配置的半成品;组件是从技术维度上的复用;模块是从 业务维度上职责的划分;系统是相互协同可运行的实体。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值