软件架构风格-5大基础风格

基本概念:
1、软件架构(体系结构)风格是描述某一特定应用领域中系统组织方式的惯用模式。
2、一个架构定义一个词汇表和一组约束。

3、词汇表中包含一些构件和连接件类型。
4、约束指出系统是如何将这些构件和连接件组合起来的。

架构风格速记

一、5大基本架构风格

1.数据流风格

面向数据流,按照一定的顺序从前往后执行程序,代表风格有批处理-管道过滤器。

1.1 批处理风格

构件为一系列固定顺序的计算单元,构件之间只通过数据传递交互。每个处理步骤是一个独立的程序,每一步必须在其前一步结束后才能开始,数据必须是完整的,以整体的方式传递。

1.2 管道-过滤器风格

每个构件都有一组输入和输出,构件读取输入的数据流,经过内部处理,产生输出数据流。前一个构件的输出作为后一个构件的输入,前后数据流关联。过滤器就是构件,连接件就是管道。

2.调用/返回风格

构件之间存在互相调用的关系,一般是显示调用,代表风格有主程序/子程序、面向对象、层次结构(C/S架构风格本质属于层次风格)。

2.1 主程序/子程序

单线程控制,把问题划分为若干个处理步骤,构件即为主程序和子程序,子程序通常可合成模块。过程调用作为交互机制,充当连接件的角色。调用关系具有层次性,其语义逻辑表现为主程序的正确性取决于它调用的子程序的正确性。

2.2 面向对象

构件是对象,连接件是对象间交互的方式,对象是通过函数和过程的调用来交互的。

2.3 层次结构

构件组成一个层次结构,连接件通过决定层间如何交互的协议来定义。修改某一层,最多影响其相邻的两层。
例如:网络ISO的7层模型,三层BS架构

3. 独立构件风格

构件之间是互相独立的,不存在显示的调用关系,而是通过某个事件触发、异步的方式来执行,代表的风格有进程通信、事件驱动系统(隐式调用)。

独立构件风格与调用/返回风格对比:

独立构件风格的优缺点:

3.1 进程通信

构件是独立的进程,连接件是消息传递。构件通常是命名过程,消息传递的方式可以是点对点、异步或同步方式,以及远程过程调用。

3.2 事件驱动系统(隐式调用)

构件不直接调用一个过程,而是触发或广播一个或多个事件。构件中的过程在一个或多个事件中注册,当某个事件被触发时,系统自动调用在这个事件中注册的所有过程。一个事件的触发就导致了另一个模块中的过程调用。这种风格中的构件是匿名的过程,它们之间交互的连接件往往是以过程之间的隐式调用来实现的。
优点: 为软件复用提供了强大的支持,为构件的维护和演化带来了方便;
缺点: 构件放弃了对系统计算的控制;

4.虚拟机风格

自定义了一套规则供使用者使用,使用者基于这个规则来开发构件,能够跨平台适配,代表风格有解释器、基于规则的系统。
场景:OA中工作流引擎,自定义批假系统,图形化拖拽,低代码平台

例如:
1、JVM(解决java语言跨平台问题)。
2、VMvare:体验其他操作系统。

4.1 解释器

通常包括一个完成解释工作的解释引擎、一个包含将被解释的代码的存储区、一个记录解释引擎当前工作状态的数据结构,以及一个记录源代码被解释执行的进度的数据结构。具有解释器风格的软件中含有一个虚拟机,可以仿真硬件的执行过程和一些
关键应用,缺点是执行效率低。

4.2 基于规则的系统

可以理解为解释器的升级版,包括规则集、规则解释器、规则/数据选择器和工作内存,一般用在人工智能领域和DSS(决策支持系统)中。

5.仓库风格

以数据为中心,所有的操作都是围绕建立的数据中心进行的,代表的风格有数据库系统、超文本系统、黑板系统。

5.1 数据库系统

构件主要有两大类,一类是中央共享数据源,保存当前系统的数据状态;另一类是多个独立处理单元,处理单元对数据元素进行操作。

5.2黑板系统

包括知识源、黑板和控制三部分。知识源包括若干独立计算的不同单元,提供解决问题的知识。知识源响应黑板的变化,也只修改黑板;黑板是一个全局数据库,包含问题域解空间的全部状态,是知识源相互作用的唯一媒介;知识源响应是通过黑板状态的变化来控制的。黑板系统通常应用在对于解决问题没有确定性算法的软件中(信号处理、问题规划和编译器优化等)

5.3 超文本系统

构件以网状链接方式相互连接,用户可以在构件之间进行按照人类的联想思维方式任意跳转到相关构件。通常应用在互联网领域。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值