当前位置:网站首页>【系统架构】-软件架构的5大风格
【系统架构】-软件架构的5大风格
2022-06-23 12:05:00 【华为云】

软件架构的概念
软件架构 = 软件体系结构,架构设计就是需求分配,将满足需求的职责分配到组件上。
架构的本质
1、软件架构为软件系统提供一个结构、行为和属性的高级抽象
2、软件架构风格是特定应用领域的惯用模式,架构定义一个词汇表和一组约束。
架构的作用
1、软件架构是项目干系人进行交流的手段
2、软件架构是可传递和可复用的模型,通过研究软件架构可能预测软件的质量
3、软件架构使推理和控制的更改变的简单,有助于循序渐进的原型设计,可以作为培训的基础
架构发展历程

架构4+1视图

软件架构风格
- 架构风格反映了领域中众多系统所共有的结构和语义特性,并指导如何将各个构件有效的组织成一个完整的系统
- 架构风格定义了用于描述系统的术语表和一组指导构建系统的规则
| 五大架构风格 | 子风格 |
|---|---|
| 数据流风格 | 批处理、管道-过滤器 |
| 调用/返回风格 | 主程序/子程序、面向对象、层次结构 |
| 独立构件风格 | 进程通信、事件驱动系统(隐式调用) |
| 虚拟机风格 | 解释器、规则系统 |
| 仓库风格 | 数据库系统、黑板系统、超文本系统 |
数据流风格

前一步的处理结果是后一步的输入内容【数据驱动】
| 优点 | 缺点 | 实例 |
|---|---|---|
| 1、松耦合【高内聚-低耦合】 2、良好的重用性、可维护性 3、可扩展性【标准接口适配】 4、良好的隐蔽性 5、支持并行 | 1、交互性较差 2、复杂性较高 3、性能较差(每个过滤器都需要解析和合成数据) | 传统编译器 网络报文处理 |
调用/返回风格

这应该很好理解,程序里用的是最多的了。
子风格:
特别讲解下子风格分层架构风格:
独立构件风格
架构解耦
| 优点 | 缺点 | 特点 |
|---|---|---|
| 1、松耦合 2、良好的重用性、可修改性和可扩展性 | 1、构件放弃了对系统计算的控制。一个构件触发一个事件时,不能确定其他构件是否会响应。即使知道了事件注册哪些构件,也不能保证这些过程被调用的顺序 2、数据交换的问题 3、过程的语义必须依赖被触发事件的上下文约束 | 系统由若干子系统构成且成为一个整体;系统由统一的目标;子系统有主从之分;每一个子系统有自己的事件收集和处理机制 |
虚拟机风格


仓库风格
比如数据库、数据中台等
其他
闭环控制风格

- 适用于嵌入式系统,用于解决简单闭环控制问题
- 经典应用:空调温控、定速巡航
C2风格

C2架构基本规则:
- 构件和连接件都有一个顶部和一个底部
- 构件的顶部要连接到连接件的底部,构件的底部要连接到连接件的顶部,构件之间不允许直连
- 一个连接件可以喝任意数目的其他构件和连接件连接
- 当两个连接件直接连接时,必须由其中一个的底部到另一个的顶部
以上就是软件架构的5大风格,关注我,给你分享更多知识。
边栏推荐
- 状态机框架
- 首次曝光!唯一全域最高等级背后的阿里云云原生安全全景图
- QT knowledge: detailed explanation of view frame qgraphicswidget
- WC statistics are out of date, and every line of cloc code is valid
- Halcon principle: correlation matching
- Runtime application self-protection (rasp): self-cultivation of application security
- 根据你的工作经历,说说软件测试中质量体系建设
- 安装Rstudio Desktop和Rstudio Server免费版本
- go-zero微服务实战系列(六、缓存一致性保证)
- Qt知识:视图框架QGraphicsWidget详解
猜你喜欢

mysql innodb的redo log buffer中未commit的事务持久化到redo log后,万一事务rollback了怎么办?

Analysis of six dimensional chart: analysis of enterprise growth of CSCEC

ROS2知识(2):网络设施

并购增资或将有望启动东软越通新动能?

Qt 知识:使用 QGraphicsPixmapItem类

想学习eTS开发?教你开发一款IQ-EQ测试应用
![Halcon principle: one dimensional function_ 1D type [1]](/img/ab/c0aee923fd0a9dd8a52b8cf31a6cd7.png)
Halcon principle: one dimensional function_ 1D type [1]

ROS察微【57】:配置手臂机器人来抓东西

Halcon原理:auto_threshold算子
![[cloud native & microservice viii] source code analysis of weightedresponsetimerule of ribbon load balancing strategy (response time weighting)](/img/cc/afad5b5d327416c809be3b661bcc13.png)
[cloud native & microservice viii] source code analysis of weightedresponsetimerule of ribbon load balancing strategy (response time weighting)
随机推荐
AssetBundle资源管理
Explain the relationship between pyqt5 signal and slot in detail
Halcon principle: one dimensional function_ 1D type [1]
QT知识:Qt Widgets小部件类【01】
Voice module: pyttsx sound change project
UI框架
ROS知识:librviz库的调用实践
如何卸载Gazebo与重装
QT knowledge: detailed explanation of view frame qgraphicswidget
国产化信息 | 爱可生与中科方德完成产品兼容互认证
记录
halcon原理:一维函数function_1d类型【1】
Ros2 knowledge (1): start practicing robots
Learning notes sweep crawler framework
Common fault analysis and Countermeasures of MySQL in go language
数据中台稳定性的“四高” | StartDT Tech Lab 18
Huawei cloud gaussdb heavily released HTAP for commercial use, defining a new paradigm of cloud native database 2.0
IPSec传输模式下ESP报文的装包与拆包过程
halcon原理:相关性匹配
Capacitated Facility Location Problem容量有限设施选址问题