【UML建模】用例图

news2025/1/17 3:57:41

1   参与者

参与者的概念:
指系统以外的、需要使用系统或与系统交互的外部实体
可以分为:人、外部设备、外部系统
参与者的图形符号:
3.1  在一个银行业务系统中,可能会有以下参与者
客户 :在银行业务系统中办理了账户的居民。他们通过银行业务系统进行金融交易
柜台营业人员 :负责银行业务系统具体操作事务的办事人员。他们为客户办理存款、取款等金融交易
Mail 系统 :负责银行业务系统向个人发送电子邮件的软件系统

知识点----参与者之间的关系

参与者之间的关系:

1.1泛化关系

泛化关系 :一般参与者与特殊参与者之间的关系

 

在一个大学图书管理系统中,可能的需求如下:

        读者在大学图书管理系统中办理了借书证。读者分学生和教师。读者借还书籍要通过图书管理员之手来完成。系统管理员负责大学图书管理系统的借书证维护和图书数据维护等操作。读者可以自己在终端机上直接进行借还书,也可以通过图书管理员来完成。

 

参与者之间的泛化关系的作用
在一个网上购物系统中,一定会遇到用户权限问题。普通用户只能浏览网站上陈列的商品,而注册会员除了普通用户具有的操作之外,还有权限进行在线购物

 

参与者之间的泛化关系的作用
共同点 :普通用户操作的所有功能,注册会员也能操作
不同点 :注册会员还能操作普通用户不能操作的功能
结论 :普通用户作为一般参与者,注册会员作为特殊参与者

 

参与者之间的泛化关系的作用
有效地减少了参与者与用例之间的关联关系的个数,简化了用例模型

 

 

1.2关联关系

关联关系:起通信的作用,即描述了:一个参与者完成系统的一项功能

 

2   用例

2.1   用例的概念

是对一个参与者使用系统的一项功能时所进行的交互过程的一个文字描述序列
是参与者可以感受到的系统服务或功能单元
注意:功能及功能涉及的交互过程,两者都重要
用例的图形符号
§ 在一个大学图书管理系统中,可能的需求如下:

        读者在大学图书管理系统中可以查找图书。读者分学生和教师。读者借还书籍要通过图书管理员之手来完成。为了方便工作,图书管理员也可以查找图书。系统管理员负责大学图书管理系统的借书证维护和图书数据维护等操作。

用例图:

2.2   用例之间的关系

用例的特征
  • 站在系统外部,看到的系统功能
  • 用户提出的一些可见的功能需求
  • 总是被参与者启动
  • 必须是一个完整的描述
  • 可以进行独立的功能检测
  • 是对系统行为的动态描述
  • 用例的设置代表了软件系统的功能划分
  • 用例的实例是系统的一次具体执行过程
  • 动态执行过程可以用UML的交互作用来说明
提问:试分析下述系统中,有哪些用例
3.6超市购买商品系统的部分需求陈述如下:
顾客带着所要购买的商品到达超市的一个销售点终端(终端设在门口附近),销售点终端负责接收数据、显示数据和打印购物单。
营业员通过销售点终端录入每项商品的通用产品代码,如果出现多个同类商品,营业员还要录入该商品的数量。系统确定商品的价格,并将商品代码、数量信息加入到正在运行的系统;系统显示当前商品的描述信息和价格。

 

找出上例中的参与者与用例

找参与者,主要找系统外的客观实体:
顾客,营业员,销售点终端。
找用例,主要找参与者看到的功能:
接收数据(接收顾客购买的商品的信息),
显示数据(显示顾客购买的商品的信息),
打印购物单(打印顾客购买的商品的信息),
商品信息维护(确定每件商品的代码及单价)
用例之间的关系:泛化关系包含关系扩展关系 
泛化关系 特殊用例 继承、覆盖、增加 一般用例 的行为
3.7  在一个在线股票经纪人系统中,下图给出了交易行为中部分交易类型之间的关系

泛化关系特殊用例继承、覆盖、增加一般用例的行为

3.8  在一个学校信息管理系统中,下图给出了查找人行为中部分特殊身份查找之间的关系

包含关系 基本用例 的行为必然执行 包含用例 的行为
3.9  在一个网上购物系统中,当注册会员在线购物时,网上购物系统需要对顾客的信用进行检查,检查输入的信用卡号是否有效
扩展关系 基本用例 的行为条件执行 扩展用例 的行为
3.10  在一个图书借阅系统中,当读者还书时,如果借书时间超期,则需要交纳一定的滞纳金,作为罚款

 

共同点:包含用例和扩展用例都补充了基本用例的行为

不同点:包含用例必然被执行,扩展用例条件被执行
性质:因为基本用例的行为被包含用例或扩展用例的行为延伸了,所以基本用例的行为依赖于包含用例或扩展用例的行为。所以,包含关系和扩展关系都是依赖关系的特例

在一个网上购物系统中,当注册会员浏览商品时,他可能临时决定在线购物。当他决定在线购买商品后,就必须下订单。此外,他也可以直接在线购物。

 

在一个停车场信息系统中,可能的需求如下:

1、汽车到达入口处,驾驶员停下车,在取卡机上按下取卡按钮,获得停车卡。

2、取出停车卡后,系统启动栏杆抬起。汽车通过后,栏杆放下。

3、驾驶员在缴费机上缴费后,获得出场卡。

4、汽车到达出口处,驾驶员停下车,插入出场卡。若出场卡有效,则栏杆抬起;否则不抬起,并发出警报。

 

2.3   用例之间的包含关系和扩展关系的区别

在扩展关系中,基本用例是可以独立存在的用例。

在包含关系中,基本用例一定会执行包含用例部分。

如果需要重复处理两个或多个用例时,可以考虑使用包含关系,实现一个基本用例对另一个用例的引用。

当处理正常行为的变形而且只是偶尔描述时,可以考虑只用泛化关系。

当处理正常行为的变形而且希望采用更多的控制方式时,可以在基本用例中设置扩展点,使用扩展关系。

  

在一个网上购物系统中,当注册会员浏览网站时,他可能临时决定购买商品。当他决定购买商品后,就必须将商品放进购物车,然后下订单。 

如果网上购物系统的需求是这样的:注册会员既可以在线购物,又可以浏览商品后决定在线购物。则 

相同点:它们都是基本用例行为的一部分。换句话说,最初的基本用例中的部分行为被提取出来,单独形成了一个用例。

不同点:在基本用例的每一次执行时,包含用例都一定会被执行,而扩展用例只是偶尔被执行。

关系是模型元素之间具体的语义联系。关系可以分为关联、泛化、依赖、实现等几种。

泛化关系表示的是两个类元之间的关系。

依赖关系表示的是两个元素或元素集之间的一种关系。

3   用例描述

用例描述
是一个关于参与者与系统如何交互的规范说明
没有描述 的用例就像是一本书的 目录 ,人们只知道该目录标题,但并不知道该目录的具体内容是什么
不同的问题域 ,相同名字的用例可能完成不同的操作过程

银行“取款”用例的用例描述

基本流程
1 、要求用户重新输入密码进行验证
2 、密码正确后,用户输入取款金额
3 、判断该储户的账户余额是否足额
4 、若足额,则输出等额的人民币现金。修改账户余额
5 、若不足额,则本次取款操作失败

 

4   用例建模

用例模型主要应用在需求分析时使用。

用例建模的基本步骤:

(1)找出系统外部的参与者和外部系统,确定系统的边界和范围。

(2)确定每一个参与者所期望的系统行为,即参与者对系统的基本业务需求。

(3)把这些系统行为作为基本用例。

(4)区分用例的优先次序。

(5)细化每个用例。使用泛化、包含、扩展等关系处理系统行为的公共或变更部分。

(6)编写每个用例的用例描述。

(7)绘制用例图。

(8)编写项目词汇表。

确定系统的边界:

系统边界是指系统与系统之间的界限
系统边界定义了由谁或什么(即参与者)来使用系统,系统能够为参与者提供什么特定服务
确定系统边界就是要定义好什么是系统的组成部分(边界内)和什么是系统的外部(边界外)
在用例图中,系统边界用实线方框图形符号表示
用例绘制在方框里面(即边界里面)
参与者绘制在方框外面(即边界外面)

 

5   用例建模中常见的问题分析

用例的设计原则

1、需求和用例的关系

2、需求应该有层次地组织起来

3、不要从用例直接推论出设计

用例模型的复杂度

1、用例包

2、用例的粒度

3、用例图

用例模型的检查

1、功能需求的完备性

2、模型是否易于理解

3、是否存在不一致性

4、避免二义性语义

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

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

相关文章

图像处理技术与应用(一)

图像处理技术与应用入门 使用skimage进行图像读取和显示 skimage库(Scikit-image)提供了一个强大的工具集,用于执行各种图像处理任务。以下是如何使用skimage读取和显示图像的基本示例: from skimage import ioimg io.imread(…

华为sr-mpls policy配置案例

SR-MPLS POLICY在ensp上面做不了,这是官方上的配置

金铲铲无限金币-罗小黑最新

罗小黑最新,下载自测。 记得查看注意事项。 获取链接:https://pan.baidu.com/s/1mRuQPAqWXv6oeihQ5fsn0w?pwdd0s3 提取码:d0s3 --来自百度网盘超级会员V1的分享

Apache Answer 开源问答社区安装体验

Answer 是由 SegmentFault 思否团队打造的一款问答平台软件,后端使用 Go 语言编写,于2022年10月24日(程序员节)正式开源。你可以免费使用 Answer 高效地搭建一个问答社区,并用于产品技术问答、客户支持、用户交流等场景。 2023年10月9日,Answer 顺利通过投票,以全票通过…

spring的跨域问题

跨域问题 什么是跨域解决跨域 什么是跨域 跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。如果出现了以下情况中的任意一种,那么它就是跨域请求: 1、协议不同,如 http 和 h…

Ubuntu 自己写的程序如何创建快捷方式

在Ubuntu中创建程序的快捷方式通常是通过将一个指向程序可执行文件的.desktop文件放入/usr/share/applications/或用户的~/.local/share/applications/目录来实现的。以下是创建快捷方式的基本步骤和示例: 在application里创建快捷方式 创建一个新的.desktop文件。…

把 WordPress 变成 BaaS 服务:API 调用指南

有了前面两篇内容的铺垫,我们来聊聊 WordPress 作为 CMS / BaaS 服务使用时绕不开的问题,API 调用。 这篇内容同样的,会尽量少贴代码,简单的讲清楚一件事,降低阅读负担。 写在前面 首先,我们需要进行清晰…

STM32H750时钟频率和功耗以及RTC功能测试

STM32H750时钟频率和功耗和RTC功能测试 ✨在使用STM32CubeMX修改STM32H750时钟树参数时,如果使用软件自动求解,这是一个非常耗时的操作,有时候还不一定成功,还是推荐使用手动方式进行配置,这一点和STM32其他系列不同&a…

叉车4G无线视频监控管理解决方案:提升效率,保障安全

在现代物流行业中,叉车被广泛应用于仓储和物流领域,成为提升效率和降低成本的重要工具。然而,叉车作为重要的运输设备,其安全性和管理效率也备受关注。针对这一问题,叉车4G无线视频监控管理解决方案应运而生。 叉车是仓…

RB-Tree

RB-tree 平衡二叉搜索树 元素排列规则有利于search 和 insert red-black tree(红黑树)是平衡二元搜索树(balanced binary tree)。其特征:排列规则有利于Search和Insert,并保持适度平衡—无任何节点过深。rb_tree提供两种插入操作:inset_unique和insert…

Rest微服务案例

Rest 父工程构建microservicecloud-api公共子模块Modulemicroservicecloud-provider-dept-8001部门微服务提供者Modulemicroservicecloud-consumer-dept-80部门微服务消费者Module 以Dept部门模块做一个微服务通用案例 Consumer消费者(Client)通过REST调…

HF区块链链码基础

链码生命周期 一 . 链码准备 准备文件 . 在测试目录下创建chaincode,拷贝测试链码进 chaincode目录,拷贝 set-env.sh 脚本进 scripts 目录 二. 打包链码 打包测试链码 export FABRIC_CFG_PATH${PWD}/config peer lifecycle chaincode package ./chaincode/chaincode_basic.…

什么是信息熵?

什么是信息? ​ 我们在日常生活中吃瓜的时候总会说信息量太大了,那么这个信息是怎么个意思呢?我们在听到的时候很多原因都是因为这个消息是新鲜的,我们没见过的,没听说过,所以就说是信息量大。 信息熵 2…

重学java 22.面向对象 继承、抽象综合案例

我们纵横交错,最后回到原点 —— 24.4.23 综合案例 流程思维图 代码实现 方式1 利用set方法为属性赋值 父类: public abstract class Development extends Employee{}子类1: public class JavaEE extends Development{Overridepublic void w…

【软考高项】二十四、整合管理基础内容

一、概述内容 定义 项目整合管理包括识别、定义、组合、统一和协调项目管理过程组的各个过程和项目管理活动,项目整合管理贯穿项目始终。目标 ①资源分配;②平衡竞争性需求;③研究各种备选方法;④裁剪过程以实现项目目标;⑤管理各个项目管理知识领域之间的…

前端性能分析工具及使用

Lighthouse Lighthouse (谷歌浏览器的插件商店中搜索并安装,浏览器中点击F12,开发者工具中可使用)是 Google 开发的一款工具,用于分析网络应用和网页,收集现代性能指标并提供对开发人员最佳实践的意见。只要…

node.js版本降级/升级

第一步.先清空本地安装的node.js版本 按健winR弹出窗口,键盘输入cmd,然后敲回车(或者鼠标直接点击电脑桌面最左下角的win窗口图标弹出,输入cmd再点击回车键) 进入命令控制行窗口,输入where node,查看本地…

关于YOLO模型架构中的strides

在Ultralytics YOLO模型架构中,m.stride是一个非常关键的属性,用于描述网络在不同尺度(scale)上的空间压缩程度。解释m.stride的原理之前,我们首先要了解深度学习中卷积神经网络(CNN)的基本工作…

png图片如何缩小体积?这个方法效果不错

图片压缩是我们生活中经常都会遇到的问题。在日常工作中图片体积过大的话,在使用过程中就会收到影响,比如加载过慢等。那么,当我们想要对png图片进行压缩处理的时候,要怎么操作呢?很简单,使用图片在线压缩&…

【sping】在logback-spring.xml 获取项目名称

在日志文件中我们想根据spring.application.name 创建出的文件夹。 也不想死在XML文件中。 application.yml spring:application:name: my-demo logback-spring.xml <springProperty name"application_name" scope"context" source"spring.app…