说先说明下: 都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
1 、包含(include)
包含关系:使用包含(Inclusion )用例来封装一组跨越多个用例的相似动作(行为片断),以便多个基(Base )用例复用。基用例控制与包含用例的 关系,以及被包含用例的事件流是否会插入到基用例的事件流中。基用例可以依赖包含用例执行的结果,但是双方都不能访问对方的属性。
包含关系对典型的应用就是复用,也就是定义中说的情景。但是有时当某用例的事件流过于复杂时,为了简化用例的描述,我们也可以把某一段事件流抽象成为一个被包含的用例;相反,用例划分太细时,也可以抽象出一个基用例,来包含这些细颗粒的用例。这种情况类似于在过程设计语言中,将程序的某一段算法封装成一个子过程,然后再从主程序中调用这一子过程。
例如:业务中,总是存在着维护某某信息的功能,如果将它作为一个用例,那新建、编辑以及修改都要在用例详述中描述,过于复杂;如果分成新建用例、编辑用例和删除用例,则划分太细。这时包含关系可以用来理清关系。
2 、扩展(extend)
扩展关系:将基用例中一段相对独立并且可选的动作,用扩展(Extension )用例加以封装,再让它从基用例中声明的扩展点(Extension Point )上进行扩展,从而使基用例行为更简练和目标更集中。扩展用例为基用例添加新的行为。扩展用例可以访问基用例的属性,因此它能根据基用例中扩展点的当前状态来判断是否执行自己。但是扩展用例对基用例不可见。
对于一个扩展用例,可以在基用例上有几个扩展点。
例如,系统中允许用户对查询的结果进行导出、打印。对于查询而言,能不能导出、打印查询都是一样的,导出、打印是不可见的。导入、打印和查询相对独立,而且为查询添加了新行为。因此可以采用扩展关系来描述:
4 、泛化(generalization)
泛化关系:子用例和父用例相似,但表现出更特别的行为;子用例将继承父用例的所有结构、行为和关系。 子用例可以使用父用例的一段行为,也可以重载它。父用例通常是抽象的。在实际应用中很少使用泛化关系,子用例中的特殊行为都可以作为父用例中的备选流存在。
例如,业务中可能存在许多需要部门领导审批的事情,但是领导审批的流程是很相似的,这时可以做成泛化关系表示:
上面是我参考的一篇文章,觉得将三种关系的区别讲得很清晰,在此基础上结合自己的系统,对项目( 在线购物系统) 的用例做了整体的描绘。
*****************************************************************
(1) 系统整体用例图
按照先整体用例,后子系统用例来进行描绘的,欢迎大家提出好的建议!
转:UML 中扩展和泛化的区别
泛化表示类似于OO 术语“ 继承” 或“ 多态” 。UML 中的Use Case 泛化过程是将不同Use Case 之间的可合并部分抽象成独立的父Use Case ,并将不可合并部分单独成各自的子Use Case ;包含以及扩展过程与泛化过程类似,但三者对用例关系的优化侧重点是不同的。如下:
● 泛化侧重表示子用例间的互斥性;
● 包含侧重表示被包含用例对Actor 提供服务的间接性;
● 扩展侧重表示扩展用例的触发不定性;详述如下:
既然用例是系统提供服务的UML 表述,那么服务这个过程在所有用例场景中是必然发生的,但发生按照发生条件可分为如下两种情况:
⒈ 无条件发生:肯定发生的;
⒉ 有条件发生:未必发生,发生与否取决于系统状态;
因此,针对用例的三种关系结合系统状态考虑,泛化与包含用例属于无条件发生的用例,而扩展属于有条件发生的用例。进一步,用例的存在是为Actor 提供服 务,但用例提供服务的方式可分为间接和直接两种,依据于此,泛化中的子用例提供的是直接服务,而包含中的被包含用例提供的是间接服务。同样,扩展用例提供的也是直接服务,但扩展用例的发生是有条件的。
另外一点需要提及的是:泛化中的子用例和扩展中的扩展用例均可以作为基本用例事件的备选择流而存在。
网上寻找 留个标记大家当共同学习!
转自:http://www.cnblogs.com/blueSkys/archive/2010/04/15/1712652.html
分享到:
相关推荐
**UML用例视图详解** UML(统一建模语言)是软件开发过程中广泛使用的建模工具,它提供了一种标准化的方式来描述系统的结构和行为。在UML中,用例视图是系统需求分析阶段的关键组成部分,它主要用于描绘系统与外部...
### 完整电子商务系统UML用例建模 #### 一、引言 在软件开发过程中,使用统一建模语言(UML)进行系统分析与设计已成为业界的标准做法。本篇文档将详细介绍一个完整的电子商务系统的UML用例建模过程。通过这份资料...
### UML用例建模详解 #### 一、引言 用例建模作为统一建模语言(UML)中的核心组成部分,为软件开发者提供了一种直观且有效的手段,用以捕捉和理解系统的需求。这一章节旨在深入探讨用例建模的概念、结构以及其在...
**UML用例和用例图详解** UML(统一建模语言)是一种标准化的建模工具,用于软件开发过程中描述系统的行为和结构。在UML中,用例(Use Case)和用例图是重要的建模元素,它们主要用于描述系统功能需求以及参与者与...
### UML统一用例方法详解 #### 一、引言 用例技术作为近几十年来最重要的需求分析技术之一,对于确保各类软件项目的成功至关重要。随着技术的发展,不同的用例方法逐渐形成并发展起来,其中最具代表性的两种方法是...
UML 序列图详解 UML 序列图是一种常用的建模工具,用于描述对象之间的交互和顺序。它能够帮助开发者和业务人员更好地理解和交流系统的行为。 在 UML 序列图中,框架元件扮演着重要的角色,它可以作为图形化边界,...
### UML中的用例建模知识点详解 #### 一、UML概述 统一建模语言(Unified Modeling Language,简称UML)是一种标准化的图形化语言,用于软件工程中描述、可视化、构造和文档化软件系统的架构。UML的目的是帮助...
### 统一建模语言UML轻松入门之用例详解 #### 一、引言 在软件工程领域,**统一建模语言**(Unified Modeling Language, UML)是一种广泛使用的标准建模语言,它帮助开发者更好地理解和构建软件系统。在UML的各种...
华迪实训提供的用例模型案例涵盖了UML的核心要素,包括UML简介、用例模型的基本概念、各种关系的定义及其在系统建模中的应用。通过300分钟的课程,详细讲解了用例泛化、扩展、包含关系,以及用例图和通信关联关系。...
《UML各种图详解》 UML(统一建模语言)是软件开发中的一种标准化建模工具,用于描绘系统的各种视图,以清晰地表达软件和系统的架构、行为和关系。本文将深入探讨UML中的两种重要图表:用例图和类图。 用例图是UML...
"UML-类图详解" UML 类图是 UML 的静态机制中一个重点,它不但是设计人员关心的核心,更是实现人员关注的核心。类图显示了一组类、接口、协作以及他们之间的关系。 一、类的定义 类是具有相似结构、行为和关系的...
### UML方法中的用例详解 #### 一、引言 用例作为一种广泛采用的需求捕捉与记录机制,在软件工程领域中扮演着至关重要的角色。它不仅有助于清晰地定义功能需求,还能有效地沟通客户与开发团队之间的期望。本文将...
UML 2.0 中的 14 种图详解 UML(Unified Modeling Language)统一建模语言,是面向对象软件的标准化建模语言。UML 2.0 共包括 14 种图形,大致分成静态图和动态图两类。最常用的 UML 图包括:用例图、类图、组件图...
### UML用例图详解与初学者指南 #### 一、引言 统一建模语言(Unified Modeling Language,简称UML)是一种广泛应用于软件工程领域的标准化建模语言,旨在帮助软件开发人员更好地理解和构建复杂的软件系统。其中,...
用例图(Use Case Diagram)是统一建模语言(UML)中的一种图表,用于展现一个系统与它的主要交互者(参与者)之间的动态关系,以及系统提供的功能(用例)。用例图是描述系统功能需求和使用场景的有效工具,有助于...
**UML(统一建模语言)详解** UML,全称为Unified Modeling Language,是一种用于软件系统分析和设计的标准建模语言。它通过图形化的方式帮助软件开发者表达和交流设计思想,提高了开发团队之间的沟通效率,降低了...
- 在用例图中,"用例"代表系统执行的动作,"参与者"是与系统交互的角色,而"关系"(关联、扩展、包含等)则描述了用例间的联系。 - 用例图有助于识别系统的功能需求,为后续的设计和开发提供基础。 2. **类图...
用例图描绘了这些用例及其关系。 9. **包与组件**:包是一种组织模型元素的方式,它可以包含类、接口和其他包。组件则表示系统中的物理模块,可以是可替换的软件单元。 通过《UML exercise resolution答案》和...