软件分析和设计过程的重要图形(架构图)

架构图(4+1视图)

总体

架构蓝图 -- 软件架构的“4+1”视图模型 https://xie.infoq.cn/article/f371c72ecc192407e5620f6e4

 

  • 结构化开发方法:分析阶段(数据流图DFD、ER图)、设计阶段(层次化的模块结构图(可以称为 组件图) 或 层次化的系统结构图)
  • 面向对象开发方法:分析阶段(类图)、设计阶段(类图)

一种视图:场景视图(用例图)

一文掌握14种UML图 : https://cloud.tencent.com/developer/article/1684161

  • 【概念】用例图是指由参与者、用例,边界以及它们之间的关系构成的用于描述系统功能的视图。
  • 【目的】用来描述整个系统的功能。

用例图中包含以下三种关系:

  • 包含关系使用符号《include》,想要查看订单列表,前提是需要先登录。
  • 扩展关系使用符号《extend》,基于查询订单列表的功能,可以增加一个导出数据的功能(如果xx,则xx  分支功能
  • 泛化关系,子用例继承父用例所有结构、行为和关系。

 

记忆:(先有谁,就指向谁)包含谁、指向谁;扩展谁,指向谁 

包含(扩展 无要求):如果没有子用例,基用例无法完成
扩展:如果xxx,则xxx(分支流)

四种视图

1.  逻辑视图(组件图/类图)

1.1 组件图

https://www.zhihu.com/tardis/zm/art/352590602?source_id=1003,https://bbs.huaweicloud.com/blogs/375202

 

描述 软件的模块及其之间的关系

最简单的组件图:

下面springcloud微服务的逻辑视图示例(仅部分),就描述了springcloud中各个功能组件。从这个图中,基本可以对springcloud有一个大颗粒度的了解。

 
咱们以java体系架构来说明逻辑视图,下图描述了java体系中各个功能组件,以及他们的层级关系,作用和依赖范围。

 

1.2 类图

2. 处理流程视图(流程图/时序图)

流程图、顺序图、状态图他们三者分别解决什么样的问题? https://www.zhihu.com/question/23356888

3. 开发视图

4. 物理视图

软件需求分析、系统设计的图

需求分析设计之七武器  https://www.jianshu.com/p/1c4061717797

软件建模与设计过程可拆分为需求分析、概要设计和详细设计三个阶段。我们往往需要在不同阶段输出不同的设计文档。这个过程,除了自身的业务理解能力外,建模工具UML必不可少,其中常用的有七种(“七武器”):类图、用例图、时序图、活动图、状态图、组件图和部署图。

适用阶段模型图说明
需求分析:    
  类图 关注领域对象识别及其关系
  活动图 描述业务流程(一种 流程图
  用例图 通过反映用户和软件系统的交互来描述系统的功能需求
  时序图 通常用于表示对象之间的交互’这个对象可以是类对象,也可以是更大粒度的参与者’如组件、服务器、子系统等
  状态图 描述状态变迁的逻辑关系
概要设计:    
  活动图 描述子系统和组件的交互  (一种 流程图)
  时序图 通常用于表示对象之间的交互’这个对象可以是类对象,也可以是更大粒度的参与者’如组件、服务器、子系统等
  组件图 粒度比较粗,通常用以描述和设计软件的模块及其之间的关系,需要在设计早期阶段画出来
  部署图 是整个软件设计模型中比较宏观的一种图,是在设计早期就需要画的一种模型图;还可以估算服务器和第三方软件的采购成本
详细设计:    
  类图 开发工程师按照类图实现代码即可
  状态图 这个时候状态要用枚举值表示,以指导具体的开发
  时序图 常用于描述系统内部详细的接口调用时序或业务模块数据流转过程
  活动图 可用于描述一个类方法内部的计算流程
 

 

UML九种图的分类

UML九种图的分类:https://blog.csdn.net/nangeali/article/details/48953587

UML结构图与行为图整理 

一文掌握14种UML图:https://cloud.tencent.com/developer/article/1684161
UML实践详细经典教程----用例图、顺序图、状态图、类图、包图、协作图:http://www.uml.org.cn/oobject/201609092.asp?artid=18390

 

 

 

posted on 2023-05-05 16:30  gogoy  阅读(2207)  评论(0编辑  收藏  举报

导航