《系统架构设计师教程(第2版)》第10章-软件架构的演化和维护-07-软件架构维护

文章目录

  • 1. 软件架构知识管理
    • 1.1 概念
    • 1.2 架构知识的获取
    • 1.3 作用
    • 1.4 架构知识管理的现状
  • 2 软件架构修改管理
  • 3 软件架构版本管理
  • 4. 示例
    • 4.1 背景
    • 4.2 数据获取
    • 4.3 数据计算
    • 4.4 结果分析
      • 4.4.1 圈复杂度 (CCN)
      • 4.4.2 扇入扇出度 (FFC)
      • 4.4.3 模块间耦合度 (CBO)
      • 4.4.4 模块的响应 (RFC)
      • 4.4.5 模块间内聚度TCC和 LCC

软件架构维护过程设计以下内容:架构知识管理、架构修改管理、架构版本管理

1. 软件架构知识管理

1.1 概念

  • 架构知识 = 架构设计 + 架构设计决策

即,需要说明在进行架构设计时采用此种架构的原因

  • 涵盖内容:
    • 架构的解决方案
    • 产生该方案的架构设计决策、设计依据

1.2 架构知识的获取

  • 侧重于架构静态演化
  • 从架构文档等信息来源中捕捉架构知识

1.3 作用

  • 有助于架构进一步的演化
  • 为其他软件架构的相关活动提供参考

1.4 架构知识管理的现状

  • 架构相关利益者因为动机不足,不会使用文档记录架构知识
    • 相对成本高
    • 利益相关者对工程短期兴趣大于架构知识重用的兴趣
    • 开发者对创造性工作的兴趣大于反思设计决策长远影响的兴趣。
  • 即使实现了文档化,通常架构知识也不能在整个组织中得到充分的分享

如果不进行管理,关键的设计知识就会“沉没”在软件架构之中,人员发生变动,将会使“沉没”的架构知识“腐蚀”

2 软件架构修改管理

  • 思路:
    • 是建立一个隔离区域 (Rcgion of Quiescence)
    • 保障该区域中任何修改对其他部分的影响比较小,甚至没有影响
  • 做法:
    • 为此,需要明确修改规则、修改类型,可能的影响范围、副作用等

3 软件架构版本管理

  • 作用:
    • 为版本演化的控制、使用、评价等提供了可靠的依据
    • 为架构演化量化度量奠定了基础

4. 示例

4.1 背景

  • 待评估的 Web读写系统的组件图如下:
    在这里插入图片描述

4.2 数据获取

  • 操作:
    • 将组件图转换为XML文件
    • 将XML文件输入架构评估系统
    • 解析出可维护度量所需的数据,如下:

在这里插入图片描述

在这里插入图片描述

上表说明:

  • L:组件图数目
  • totalN :外部组件数目
  • totalE :与外部组件相连的边的数据
  • S:组件内部组件数目
  • E:依赖出边数目
  • X:依赖入边数目
  • R:使用接口数目
  • W:提供接口数目

4.3 数据计算

根据可维护性的6个子度量指标的度量公式,利用解析得到的架构评估数据分别进行度量

  • 圈复杂度 (CCN)
    度量整个架构的独立执行路径的条数,直接得出最终度量结果
  • 扇入扇出度 (FFC)、 模块间耦合度 (CBO)、 模块的响应 (RFC)、 紧内聚度 (TCC)、 松内聚度 (LCC)
    针对每个组件进行度量,最终度量结果取所有组件的平均值
  • 组件Client Application为各个子度量指标的计算方法:
    在这里插入图片描述
  • 其他组件的度量方法:
    • 与Client Application相同
    • 由于均没有子组件,P(S) 的果为0, 无法计算该组件模块的内聚度,以 “not applied” 表示(即,没有子组件,内聚度最小)
  • 度量结果如图所示:
    在这里插入图片描述

4.4 结果分析

4.4.1 圈复杂度 (CCN)

  • 目的:
    • 对整个系统的复杂程度做出初步评估
    • 并预测待评估系统的测试复杂度
    • 及早规避风险,提高软件质量
  • 标准: CCN≤10 为宜。

4.4.2 扇入扇出度 (FFC)

  • 概念:
    • 扇入:指直接调用该模块的上级模块的个数
    • 扇出:指该模块直接调用的下级模块的个数
  • 目的:综合评估组件主动调用以及被调用的频率
    • 扇入扇出度越大,表明该组件与其他组件间的接口关联或依赖关联越多

在这里插入图片描述

4.4.3 模块间耦合度 (CBO)

  • 目的:度量模块与其他模块交互的频繁程度

CBO越大可维护性越差,风险越高

在这里插入图片描述

4.4.4 模块的响应 (RFC)

  • 目的:度量组件执行所需的功能的数量
    • 包括:接口提供的功能、依赖的其他模块提供的功能、子模块提供的功能
      在这里插入图片描述

DB、RemoteDB、LocalDB等没有对其他模块的依赖和调用,且不包含子模块,因而其 RFC度量值为0

4.4.5 模块间内聚度TCC和 LCC

只有组件ClientApplication 具有子模块,因而对该组件进行度量,并将该组件的度量值作为待评估系统的最终结果


在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

x264 场景切换检测算法分析

x264 编码器场景切换 在 x264 编码器中,场景切换(Scene Cut)检测是一个重要的特性,它用于识别视频中不同场景之间的过渡点。这些过渡点通常是视觉上显著不同的帧,比如从一个镜头切换到另一个镜头。在这些点插入关键帧(I帧)可以提高视频的随机访问性和编码效率。 入口函…

vue 百度地图点击marker修改marker图片,其他marker图片不变。

解决思路,就是直接替换对应marker的图片。获取marker对象判断点击的marker替换成新图片,上一个被点击的就替换成老图片。 marker.name tag;marker.id i; //一定要设置id,我这里是设置的循环key值,要唯一性。map.addOverlay(mark…

SSRF(服务器端请求伪造)的学习以及相关例题(上)

目录 一、SSRF的介绍 二、漏洞产生的原因 三、利用SSRF可以实现的效果(攻击方式) 四、SSRF的利用 五、SSRF中的函数 file_get_content() 、fsockopen() 、curl_exec() 1.file_get_content(): 2.fsockopen(): 3.curl_exec()&#xff1…

【鸿蒙开发】第二十四章 IPC与RPC进程间通讯服务

1 IPC与RPC通信概述 IPC(Inter-Process Communication)与RPC(Remote Procedure Call)用于实现跨进程通信,不同的是前者使用Binder驱动,用于设备内的跨进程通信,后者使用软总线驱动,…

算法设计与分析(超详解!) 第三节 贪婪算法

1.贪心算法基础 1.贪心算法的基本思想 贪心算法是从问题的某一个初始解出发,向给定的目标推进。但它与普通递推求解过程不同的是,其推动的每一步不是依据某一固定的递推式,而是做一个当时看似最佳的贪心选择,不断地将问题实例归…

【选择结构程序设计-谭浩强适配】(适合专升本、考研)

无偿分享学习资料,需要的小伙伴评论区或私信dd。。。 无偿分享学习资料,需要的小伙伴评论区或私信dd。。。 无偿分享学习资料,需要的小伙伴评论区或私信dd。。。 完整资料如下:纯干货、纯干货、纯干货!!…

uni-app跨端兼容

1.样式兼容 小程序端不支持*选择器,可以使用(view,text) 页面视口差异(tabar页、普通页) H5端默认开始scoped 例如骨架屏样式出现问题,需要将之前的样式拷贝到骨架屏中 提示:H5端是单页面应用,scoped隔离…

【吊打面试官系列】Java高并发篇 - 如何创建守护线程?

大家好,我是锋哥。今天分享关于 【如何创建守护线程?】面试题,希望对大家有帮助; 如何创建守护线程? 使用 Thread 类的 setDaemon(true)方法可以将线程设置为守护线程,需要注意的是,需要在调用 …

家政服务新体验——家政小程序开发,让生活更轻松!

一、引言 随着现代生活节奏的加快,家政服务已经成为越来越多家庭不可或缺的一部分。然而,传统家政服务方式往往存在预约不便、服务质量参差不齐等问题。为了解决这些问题,我们精心打造了一款家政小程序,为您带来全新的家政服务体…

Codeforces Round 843 (Div. 2) B. Gardener and the Array (构造)

原题地址 The gardener Kazimir Kazimirovich has an array of n n n integers c 1 , c 2 , … , c n c_1, c_2, \dots, c_n c1​,c2​,…,cn​. He wants to check if there are two different subsequences a a a and b b b of the original array, for which f ( a ) …

学习笔记:Adaptive Platform(AP)适配到RTOS

一、背景 1、AP版本 Adaptive Platform AUTOSAR R20-11版本标准支持C14。CM模块支持DDS、SOME/IP协议 2、RTOS RTOS-A核,当前完全支持POSIX PSE51、POSIX PSE52接口,POSIX PSE53部分支持,POSIX PSE54基本不支持。详细接口参考&#xff1a…

《三》菜单栏_工具栏_状态栏动作与实现

上期我们创建了辣么多的动作,那么这次我们要是开始实现这些动作,撸起袖子来吧: //菜单动作(ACtion)QAction *newAct;//新建QAction *openAct;//打开QAction *saveAct;//保存QAction *saveAsAct;//另存为QAction *prin…

学习java

在实验室看见这本书,无聊看了下,写出了第一个java代码 成功下载了eclipse并且汉化。 写了自己的第一个java程序: package ttttt;public class ttttt {public static void main(String[] args) {System.out.println("hello world")…

DS高阶:B树系列

一、常见的搜索结构 1、顺序查找 时间复杂度:O(N) 2、二分查找 时间复杂度:O(logN) 要求:(1)有序 (2)支持下标的随机访问 3、二叉搜索树(BS树) 时间复杂…

免费的国内版 GPT 推荐,5个国产ai工具

提起AI,大家第一个想到的就是GPT。 虽然它确实很厉害,但奈何于我们水土不服,使用门槛有些高。 不过随着GPT的爆火,现在AI智能工具已经遍布到各行各业了,随着时间的推移,国内的AI工具也已经“百花盛放”了…

哈希重要思想——位图详解

一,概念 所谓位图,就是用每一位来存放某种状态,适用于海量数据,数据无重复的场景。通常是用来判断某个数据存不存在的。 为了方便理解我们引入一道面试题, 给40亿个不重复的无符号整数,没排过序。给一个无…

UniAD大模型开路,智能车驶入AGI时代

作者 |老缅 编辑 |德新 在刚刚结束不久的北京车展上,除一众明星车型亮相,供应链企业也开始大秀肌肉,其中尤其以端到端大模型为代表,焕新一代的智驾技术栈掀起了新一轮热潮。 作为首个提出感知决策一体化自动驾驶通用模型的公司&…

C++学习笔记3

A. 求出那个数 题目描述 喵喵是一个爱睡懒觉的姑娘,所以每天早上喵喵的妈妈都花费很大的力气才能把喵喵叫起来去上学。 在放学的路上,喵喵看到有一家店在打折卖闹钟,她就准备买个闹钟回家叫自己早晨起床,以便不让妈妈这么的辛苦…

创新点!CNN与LSTM结合,实现更准预测、更快效率、更高性能!

推荐一个能发表高质量论文的好方向:LSTM结合CNN。 LSTM擅长捕捉序列数据中的长期依赖关系,而CNN则擅长提取图像数据的局部特征。通过结合两者的优势,我们可以让模型同时考虑到数据的时序信息和空间信息,减少参数降低过拟合风险&a…

STM32_HAL_RTC_解决恢复电源时再一次初始化

1问题 板子再次恢复电源时直接初始化了时间 2解决思路 在初始化函数(MX_RTC_Init();)中增加判断,判断是否是二次初始化 将值放入备份存储其中 3问题图 4解决后的源码 /* RTC init function */ void MX_RTC_Init(void) {/* USER CODE BE…