高架学习笔记之软件架构风格

news2024/12/29 8:21:20

目录

零、什么是软件架构风格

一、常见的软件架构风格

二、数据流风格

2.1. 批处理风格

2.2. 管道-过滤器风格

三、调用/返回风格

3.1. 主/子程序风格

3.2. 面向对象风格

3.3. 层次型风格

3.4. 客户端/服务器风格

3.4.1. 两层C/S体系结构

3.4.2. 三层C/S体系结构

3.4.3. B/S体系结构

四、数据共享风格

4.1. 仓库风格

4.2. 黑板风格

4.3. 超文本风格

五、虚拟机风格

5.1. 解释器风格

5.2. 规则系统风格

六、独立构件风格

6.1. 进程通信风格

6.2. 事件系统风格

七、其他风格

7.1. 闭环-过程控制风格

7.2. C2风格


零、什么是软件架构风格

    软件架构设计的一个核心目标就是达到架构级的软件重用。在不同的软件系统中使用同一个架构模式,可以减少大量设计成本,使用重复的、经过验证过的成熟的架构模式也可以降低风险,避免了从头设计一套架构模式可能会产生的种种问题。

    将众多系统共有的结构和语义特性归纳起来,用于指导系统如何将各个模块和子系统有效地组织成一个完整的系统,就产生了不同的软件架构风格。简单来讲,软件架构风格就是描述某一特定应用领域中系统组织方式的惯用模式。有了软件架构风格,还可以减少系统人员之间的沟通成本,提高沟通效率,比如某人只要将系统描述为“客户/服务器”模式,而不用详细解释系统的设计细节,其他人也会立即明白系统是如何组织和工作的。

一、常见的软件架构风格

    目前,常见的软件架构风格大致可以分为6类:

    下面章节对这些软件架构风格进行详细地说明。

二、数据流风格

    数据流软件架构风格的核心思想是将软件系统中的组件视为数据处理单元,数据在这些处理单元之间流动并被处理,这种架构风格强调数据的流动和转换。在数据流软件架构中,软件系统被划分为多个独立的处理单元,每个处理单元负责特定的数据处理任务。这些处理单元可以是函数、过滤器、模块或者服务,它们按照一定的顺序连接在一起,形成数据流管道。数据从一个处理单元经过处理后,传递给下一个处理单元,直至最终完成整个数据处理流程。数据流架构风格适用于需要处理大量数据或实现复杂数据处理逻辑的软件系统。数据流架构风格具有以下优点:

1.模块化:系统被分解为多个独立的处理单元,易于维护和扩展。

2.可重用性:每个处理单元可以被重复利用在不同的数据流中。

3.灵活性:可以根据需求动态组合不同的处理单元,实现灵活的数据处理流程。

4.可伸缩性:可以通过增加或替换处理单元来实现系统的水平扩展。

    常见的数据流软件架构风格包括批处理架构风格和管道-过滤器架构风格。

2.1. 批处理风格

    在批处理风格的软件架构中,数据按照一定的顺序经过一系列数据处理单元,每一步必须在前一步处理完成后才能开始。在批处理架构风格中,数据在整个处理过程中必须保持其完整性,即每个步骤处理完成后都以整体的方式向后传递数据。

2.2. 管道-过滤器风格

    数据通过一系列管道流动,每个管道上都连接有一个或多个过滤器,用于处理数据。每个过滤器都只关注特定的数据处理任务(分析、计算、转换等),通过串联不同的过滤器可以实现复杂的数据处理逻辑。在管道-过滤器风格的架构中,不要求数据在处理过程中的完整性,每个管道只需要将处理结果向后传递即可。

三、调用/返回风格

    调用/返回软件架构的核心思想是将一个复杂的大系统分解为若干子系统,它主要强调在系统组件间的调用和返回机制。在这种架构风格中,一个组件(通常被称为服务)接收到调用者的请求后执行任务并产生一个结果,这个结果再返回给调用者。

    调用/返回架构风格的主要优点是能够将复杂的系统分解为更小、更易于管理的部分,从而降低系统的复杂度并提高其可修改性。每个组件都可以独立开发和测试。这促进了模块化编程,使得跟踪和调试变得更加容易。

3.1. 主/子程序风格

    主/子程序软件架构风格一般采用单线程控制,把问题划分为若干处理步骤,构件即为主程序和子程序。其中主程序负责控制程序的整体流程和逻辑,而子程序则负责执行特定的任务或功能。主程序通常包含程序的入口,并调用适当的子程序来完成具体的工作。调用关系具有层次性,其主程序的正确性取决于它调用的子程序的正确性。这种风格可以使程序结构清晰,易于理解和维护。

3.2. 面向对象风格

    面向对象软件架构风格强调数据(属性)和行为(方法)的封装、继承和多态。在面向对象架构中,系统被视为一组相互作用的对象集合,每个对象代表了现实世界中的实体或概念。这种架构风格有助于降低系统的复杂性,提高代码的可重用性和可维护性。

3.3. 层次型风格

    层次型软件架构风格是一种将软件系统划分为多个层次的架构模式,每个层次都负责不同的功能或业务逻辑,并通过定义好的接口与上下层进行交互。这种架构风格的特点包括:

  1. 层次划分:系统被组织成多个层次,每个层次都有明确的职责和功能。通常,上层依赖于下层提供的服务,但下层不依赖于上层。这种层次结构有助于降低系统的复杂性,并简化了开发和维护过程。

  2. 清晰的责任划分:每个层次都负责特定的功能或业务逻辑,这使得每个层次的责任清晰明确。这种划分有助于提高代码的可读性和可维护性。

  3. 松耦合:层次之间的交互通过定义好的接口进行,这有助于实现层次之间的松耦合。松耦合意味着一个层次的变化不会对其他层次产生过多的影响,从而提高了系统的可维护性和可扩展性。

  4. 易于扩展:由于层次之间的接口清晰,新功能的添加或现有功能的修改通常只需要在特定的层次上进行,而不需要对整个系统进行大规模改动。

  5. 资源利用效率高:层次型架构通常能够实现资源的有效利用,因为不同层次的资源可以根据需要进行独立的优化和管理。

3.4. 客户端/服务器风格

    客户端/服务器(C/S)软件架构风格是一种分布式计算架构,它将软件系统分为两个主要部分:客户端(Client)和服务器(Server)。这种架构风格的核心特点是客户端和服务器之间的高度分工合作,并通过网络通信进行交互,以实现系统的整体功能。

3.4.1. 两层C/S体系结构

    在两层C/S体系结构中,后台服务器一般仅负责数据管理,而将其余的功能及交互全部放在前台客户机中实现,可以称之为“胖客户机,瘦服务器”。

3.4.2. 三层C/S体系结构

    在三层C/S体系结构中,增加了一个应用服务器,将功能层独立放到应用服务器上,前台客户机仅保留最基本的表示层,即“瘦客户机”。总的来说,三层C/S体系结构包括:1)表示层:应用的用户接口部分,通常使用图形用户界面;2)功能层:应用的主体,实现具体的业务处理逻辑;3)数据层:即数据库管理系统。

3.4.3. B/S体系结构

    浏览器/服务器(B/S)体系结构严格来说并不属于传统的C/S体系结构,通常只视为C/S体系结构的一种变体,在传统的三层C/S架构中,通常包含客户端、应用服务器和数据库服务器三个层级,而B/S架构则将客户端和应用服务器合并为一个层级,通过浏览器直接访问服务器上的应用程序和数据。B/S架构和传统的C/S架构在分工和通信方式上有所不同,但它们都属于分布式计算架构的范畴,用于构建各种类型的网络应用程序。

四、数据共享风格

4.1. 仓库风格

    仓库风格主要用于处理系统中的持久化数据的存储和检索。在这种架构风格中,仓库充当了应用程序与数据库或其他持久化存储之间的抽象层。这种抽象层隐藏了底层数据存储的复杂性,并为上层业务逻辑提供了一组简单、一致的接口。其主要特点包括:

  1. 中心化数据存储:所有的数据都被集中存储在一个中心化的数据仓库中,这样可以确保数据的一致性和统一性。

  2. 统一的数据访问接口:仓库风格提供了统一的接口,使得系统中的各个组件可以通过相同的方式来访问数据仓库,简化了系统的设计和实现。

  3. 数据的集中管理:由于所有的数据都存储在同一个数据仓库中,因此可以更加方便地进行数据管理和维护,包括备份、恢复、安全性管理等方面。

  4. 易于扩展和维护:由于数据仓库是中心化的,因此对系统进行扩展或修改时,只需要对数据仓库的接口进行调整,而不需要对系统中的其他组件进行大规模的修改。

  5. 数据的共享和复用:通过统一的数据仓库,不同的组件可以共享和复用相同的数据,避免了数据的重复存储和管理,提高了系统的效率和性能。

4.2. 黑板风格

    黑板风格是一种问题求解模型,适用于解决复杂的非结构化的问题。在黑板风格中,软件系统被设计成一个分布式的问题求解网络,其中“黑板”作为一个共享的中央知识库,用于存储问题的当前状态、所有解决方案和部分解决方案。系统的各种组件就像是在一个共享的“黑板”上交流和更新信息的“专家”。每位专家都可以看到其他专家在黑板上写下的信息,并基于这些信息进行自己的分析处理,同时也可以将自己的分析结果更新到黑板上。黑板风格的主要特点包括:

  1. 灵活性:由于黑板风格允许不同的知识源独立地工作,因此它具有很强的灵活性。新的知识源可以很容易地添加到系统中,以应对新出现的问题或需求。

  2. 并行性:由于各个知识源可以独立工作,因此黑板风格支持并行处理,这有助于提高系统的整体性能

  3. 增量式开发:随着问题求解的进展,黑板上的信息会逐渐丰富和完善。这种增量式的开发方式使得系统能够逐步逼近问题的解决方案。

4.3. 超文本风格

    超文本风格是一种基于超媒体技术的系统设计方法。超文本是一种数据表示和存储技术,它允许信息以非线性方式组织,并通过链接(超链接)连接不同的信息片段。这种风格特别适用于需要灵活、动态、交互式和非线性信息导航的应用程序,如网页浏览器和一些知识管理系统。超文本风格的核心特点包括:

  1. 非线性结构:在超文本系统中,信息以网状结构组织,用户可以通过超链接在不同的信息片段之间导航,而不是遵循固定的线性路径。

  2. 动态交互:超文本系统支持动态交互,用户的行为(如点击链接)可以触发系统状态的改变,这种状态改变通常是通过客户端和服务器之间的交互来实现的。

  3. 独立性:超文本系统中的信息片段通常是独立的,这意味着它们可以被独立地创建、更新和删除,而不需要重新组织整个信息空间。

  4. 可扩展性:由于超文本结构的灵活性,这种风格的系统通常具有良好的可扩展性,新的信息片段和链接可以轻松地加入到现有的信息网络中。

五、虚拟机风格

    虚拟机风格的基本思想是人为构建一个运行环境,在这个环境上,可以解析与运行自定义的语言,以此来增加框架的灵活性。虚拟机体系结构风格主要包括解释器风格和规则系统风格。

5.1. 解释器风格

    一个解释器通常包括完成解释工作的解释引擎,一个包含将被解释的代码的存储区,一个记录解释引擎当前工作状态的数据结构,以及一个记录源代码被解释执行进度的数据结构。具有解释器风格的软件中含有一个虚拟机,可以仿真硬件的执行过程和一些关键应用。虚拟机使用解释器来执行程序代码。解释器逐条读取、解释和执行源代码,而不是先编译成机器码再执行。这种风格的优点包括易于调试和修改代码,因为源代码和执行引擎紧密耦合。但它通常比编译执行慢,因为它需要在执行之前解释每条指令。

5.2. 规则系统风格

    基于规则的系统包括规则集、规则解释器、规则/数据选择器及工作内存。规则系统风格的虚拟机基于一组预定义的规则进行决策和处理。这种风格的系统通常用于需要复杂决策流程的场景。规则引擎根据输入数据匹配规则,并执行与规则相关的操作。这种风格的优点是灵活性高,可以较容易地添加或修改规则。

六、独立构件风格

    独立构件风格是一种将软件系统划分为多个独立、可替换的构件的架构风格,每个构件在设计时都具有清晰的接口和职责,可以在运行时独立部署、升级而不影响整个系统的正常运行。这种风格强调系统中的每个构件都是相对独立的个体,它们之间一般不直接通信,以降低耦合度,提升灵活性。这种风格的主要特点包括自治性、松耦合、可重用性和分布性。独立构件风格主要包括进程通信和事件系统风格。

6.1. 进程通信风格

    进程通信风格强调的是构件之间的相互通信。在进程通信风格中,构件通常运行在不同的进程之中,它们通过消息传递或者服务请求等方式进行通信。这种风格的优点是可以降低构件之间的耦合度,提高系统的可维护性和可扩展性。

6.2. 事件系统风格

    事件系统风格侧重于构件之间的异步通信。在这种风格中,构件之间通过事件来触发相应的处理操作。当一个构件发生特定的事件时,它会通知其他构件,其他构件则根据事件进行相应的处理。这种风格可以提高系统的响应速度和性能。

七、其他风格

7.1. 闭环-过程控制风格

    闭环-过程控制风格是一种控制架构,主要用于操作物理系统。在这种架构中,软件与硬件之间的关系可以简化为一个反馈循环。这个循环通过接收一定的输入,确定一系列的输出,最终使环境达到一个新的状态。这种控制风格特别适用于嵌入式系统,这些系统涉及连续的动作和状态。

    在闭环控制系统中,与开环控制系统的主要区别在于反馈机制的存在。开环控制是给定一个值,然后由控制器对这个值进行发送指令,执行器执行这个指令,然后将控制量提交到被控制对象,控制对象按控制的情况进行执行。然而,如果没有接收到反馈,开环控制可能会出现问题,例如指令可能丢失。

    相比之下,闭环控制通过接收反馈来不断优化其输出,以更精确地达到目标。例如,在空调的例子中,无论设定温度为18度还是24度,吹出来的风的温度应该是恒定的,这是通过闭环控制空调会不断地接收环境的温度反馈,然后调整其输出(例如风速和制冷量),以保持环境温度的稳定。

7.2. C2风格

    C2风格主要用于网络化的软件应用中,特别是那些需要清晰分层和松耦合的系统。C2架构风格概括而言,是由连接件绑定的按一定规则运行的并行构件网络。在该架构风格中,各构件之间不能直接连接,只能通过连接件的异步通信机制进行交互,使得构件的替换或更新不影响架构,这种方式体现了高内聚、松耦合的设计思想。C2架构风格的主要优点包括:

  • 松耦合:上层构件对下层构件不感知,方便更新或替换下层构件。

  • 可重用:只要符合请求及响应标准,就可重用构件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1612862.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MBD_入门篇_20_Simulink子系统

20.Simulink子系统 20.1 概述 Simulink的子系统,相当于代码的function函数,但是模型的子系统又不完全等效于代码的函数。虚拟子系统并不会生成函数,而是以代码块的形式放在相应的调用位置上。模型层面我们使用子系统去做模块化的设计&#xf…

Mini-Gemini: 探索多模态视觉语言模型的新境界

一、背景 在数字化时代,人工智能的发展正以前所未有的速度推进。特别是在多模态学习领域,结合视觉和语言的能力已成为研究的热点。最近,一篇名为“Mini-Gemini: Mining the Potential of Multi-modality Vision Language Models”的文章在arX…

[已解决]react打包部署

react打包部署 问题 npm install 命令无反应 思路 换成 yarn install 安装完hadoop的环境后,使用node的yarn会报错: 我们在cmd使用where yarn,如下: 看你想保留哪一个,我平时node用的多,就把hadoop的y…

飞书API(5):查看多维表 28 种数据类型的数据结构

一、引入 前面我们用于测试的数据集其实都是比较常用的数据,比如说文本、数字、单选等,但飞书多维表并不仅仅只有这些数据,截止发文,飞书多维表应用上支持28种数据类型,在数据层面飞书官方只提供了23种数据类型&#…

Cadence软件安装

Cadence软件 iscape 用于安装cadence家的安装软件 解压缩安装包tar -xvf IScape04.23.tar.gz运行bash IScape/iscape/bin/iscape.sh 设置默认安装路径(可选)IC618 这里使用的是IC618.320版本作为示例,其他版本安装过程差不多 安装 首先安装终端模拟器,不然安装之后会失败…

【前端】校园二手书交易系统javascript+css+html (源码)【独一无二】

👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉公众号👈:测试开发自动化【获取源码商业合作】 👉荣__誉👈:阿里云博客专家博主、5…

Vnode是如何产生的?

源码 流程图 源码解读 Vue.js2.0中有两种生成方式:第一种是直接在Vue对象的option中添加render字段;第二种是像Vue.js 1.x版本那样写一个模板或者指定一个el根元素,它会首先转换成模板,经过HTMI语法解析器生成一个 ast 抽象语法树…

JAVAEE——IP协议

文章目录 IP协议IP协议报头格式IP协议报头的各个区段四位版本四位首部长度八位服务类型16位总长度16位标识,3位标志,13位片偏移八位生存时间八位协议 地址管理IP地址解决提议1:动态分配Ip地址解决提议2:NAT机制 IP协议 IP协议报头…

【新手入门必看】从零开始学指针

我使用VS CODEMSYS2的编译环境进行学习&#xff0c;想使用VS CODE进行C/C代码编写的小伙伴参考这篇文章进行环境配置VS Code 配置 C/C 编程运行环境&#xff08;保姆级教程&#xff09; 一、指针的引入 指针地址 #include <stdio.h>int main() {int a 10;printf(&quo…

编写函数fun,函数的功能是:根据以下公式计算s,计算结果作为函数值返回;n通过形参传入。

本文收录于专栏:算法之翼 https://blog.csdn.net/weixin_52908342/category_10943144.html 订阅后本专栏全部文章可见。 本文含有题目的题干、解题思路、解题思路、解题代码、代码解析。本文分别包含C语言、C++、Java、Python四种语言的解法完整代码和详细的解析。 题干 编写…

Java:二叉树(1)

从现在开始&#xff0c;我们进入二叉树的学习&#xff0c;二叉树是数据结构的重点部分&#xff0c;在了解这个结构之前&#xff0c;我们先来了解一下什么是树型结构吧&#xff01; 一、树型结构 1、树型结构简介 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>…

深度学习系列64:数字人openHeygen详解

1. 主流程分析 从inference.py函数进入&#xff0c;主要流程包括&#xff1a; 1&#xff09; 使用cv2获取视频中所有帧的列表&#xff0c;如下&#xff1a; 2&#xff09;定义Croper。核心代码为69行&#xff1a;full_frames_RGB, crop, quad croper.crop(full_frames_RGB)。…

openobserve-filebeat配置

优势 rustgolang开发的日志工具组合&#xff0c;自带日志数据存储&#xff0c;简化部署和管理。日志数据可配置保留x天。从日志文件中采集&#xff0c;做到非侵入式日志集中管理。 可从日志内容中提取信息进行报警等二次开发。 下载 openobserve-v0.10.1-windows-amd64 fil…

VL02N交货单清除字段:VLSTK(分配状态)

VL02N交货单清除字段&#xff1a;VLSTK(分配状态) 通过查找增强对应的BADI&#xff1a;LE_SHP_DELIVERY_PROC 修改方法&#xff1a;IF_EX_LE_SHP_DELIVERY_PROC~CHANGE_DELIVERY_HEADER&#xff0c;代码如下&#xff1a;

JSS作业

JSS作业&#xff1a; 1: <script>var cnt parseInt(window.prompt("请输入打印的行数&#xff1a;"));for (var i 1; i < cnt; i){for (var j 1; j < i; j){document.write("*")}document.write("<br>")} </script>…

XTuner 微调 LLM:1.8B、多模态、Agent

两种微调范式&#xff1a;增量预训练和指令微调 在大语言模型下游应用中&#xff0c;主要有两种微调范式&#xff1a;增量预训练和指令微调。增量预训练旨在让模型学习特定领域的常识&#xff0c;而不需要有监督标注的数据&#xff1b;指令微调则是通过高质量的对话数据训练模型…

C语言中, 文件包含处理,#include< > 与 #include ““的区别

文件包含处理 指一个源文件可以将另外一个文件的全部内容包含进来 &#xff23;语言提供了#include命令用来实现文件包含的操作 #include< > 与 #include ""的区别 <> 表示系统直接按系统指定的目录检索 "" 表示系统先在 "" 指定…

vulfocus靶场couchdb 权限绕过 (CVE-2017-12635)

Apache CouchDB是一个开源数据库&#xff0c;专注于易用性和成为"完全拥抱web的数据库"。它是一个使用JSON作为存储格式&#xff0c;JavaScript作为查询语言&#xff0c;MapReduce和HTTP作为API的NoSQL数据库。应用广泛&#xff0c;如BBC用在其动态内容展示平台&…

动态内存管理 柔性数组

文章目录 动态内存函数 malloc freecallocrealloc 重新开辟空间realloc 也可以第一个参数为NULL&#xff0c;则是直接开辟内存&#xff0c;类似于malloc用法 常见的动态内存错误对空指针进行解引用操作对开辟的内存越界访问对非动态开辟的内存使用free释放使用free释放动态开辟…

《Linux运维总结:Kylin V10+ARM架构CPU基于docker-compose一键离线部署redis6.2.8之容器版哨兵集群》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;《Linux运维篇&#xff1a;Linux系统运维指南》 一、部署背景 由于业务系统的特殊性&#xff0c;我们需要面向不通的客户安装我们的业务系统&…