共性:
都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
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
提供服
务,但用例提供服务的方式可分为间接和直接两种,依据于此,泛化中的子用例提供的是直接服务,而包含中的被包含用例提供的是间接服务。同样,扩展用例提供的也是直接服务,但扩展用例的发生是有条件的。
另外一点需要提及的是:泛化中的子用例和扩展中的扩展用例均可以作为基本用例事件的备选择流而存在。
分享到:
相关推荐
用例的关系有泛化(generalization)、扩展(extend)和包含(include)。其中include和extend最易混淆。下面我们结合实例彻底理清三者的关系。基本概念用例图(UseCaseDiagram):用例图显示谁是相关的用户,用户希望系统...
在 UML 用例图中,包含、扩展和泛化是三种基本关系,它们之间的区别和联系对正确理解 UML 用例图至关重要。 包含关系(Include) 包含关系是一种基本关系,它允许将一个用例拆分为多个小的用例,以便重用和简化...
在 UML 用例图中,包含、扩展和泛化是三种基本关系,它们之间的区别和应用场景是开发者需要掌握的重要知识。本文将对 UML 用例图的包含、扩展和泛化进行详细阐述,并探讨它们之间的区别和应用场景。 包含关系...
综上所述,UML用例图是理解和表达系统功能需求的强大工具,它不仅有助于需求分析,而且在整个软件开发过程中扮演着不可或缺的角色。通过合理运用用例图,开发者能够更有效地规划和实施系统开发,确保最终产品满足...
《UML用例图实例讲解》 UML(统一建模语言)是软件开发中用于系统建模的重要工具,其中用例图是描述系统功能需求的关键图表。本章将深入探讨用例图的概念、建模技术和一个实际的图书馆管理系统用例图的案例。 5.1 ...
在"uml用例图实例讲解.ppt"这个文件中,可能包含了各种用例图的例子,如银行系统的用例图,其中可能有"存款"、"取款"、"转账"等用例,以及"客户"、"ATM机"等参与者。通过这些例子,初学者可以更好地理解用例图的...
UML(统一建模语言)是软件开发中用于可视化、构造和文档化的标准工具,其中用例图是一种重要的图表类型,它描绘了系统与外部用户,即活动者之间的交互。用例图提供了一个高层次的视角,展示了系统的核心功能及其与...
《UML用例图实例讲解》 UML(统一建模语言)是软件开发中用于可视化、构建和文档化系统模型的重要工具。其中,用例图(Use Case Diagram)是UML的一种静态视图,主要用于描绘系统的主要角色、用例以及它们之间的...
### UML用例图详解及应用场景 #### 一、引言 UML(Unified Modeling Language,统一建模语言)是一种广泛应用于软件工程领域的图形化语言,用于描述软件系统的架构、行为和实现细节。其中,**用例图**是UML中最直观...
学习UML用例图,不仅能够帮助我们梳理需求,还能促进团队间的沟通,使得非技术人员也能理解复杂的系统设计。通过创建和分析用例图,我们可以发现潜在的问题,优化系统设计,确保最终产品的功能符合用户需求。 在...
7. 包含(Include)和扩展(Extend):包含关系表示一个用例包含了另一个用例的行为;扩展关系则表示一个用例可以在特定条件下扩展另一个用例的行为。 二、学习资源 1. 《UML 入门》:这本书可能提供了UML的基础...
UML 用例图是对系统的功能模型化,包括六个元素:执行者(Actor)、用例(Use Case)、关联关系(Association)、包含关系(Include)、扩展关系(Extend)以及泛化关系(Generalization)。 在 UML 用例图中,每个...
### UML用例图详解与初学者指南 #### 一、引言 统一建模语言(Unified Modeling Language,简称UML)是一种广泛应用于软件工程领域的标准化建模语言,旨在帮助软件开发人员更好地理解和构建复杂的软件系统。其中,...
用例图是一种重要的需求分析工具,主要用于描述系统的外部可见行为以及不同角色与系统交互的方式。它能够清晰地展示系统的功能需求,帮助开发者理解用户的需求,并且便于进行后续的设计与实现。 #### 二、Rational ...
在本次UML实验中,主要目的是熟悉和掌握Rose建模工具的运用,并通过构建网上书店的用例图,深入理解如何进行案例需求分析以及UML用例图的建模技术。网上书店系统涉及了多个功能模块,包括用户模块和订单管理员模块,...
总之,UML用例和用例图是软件开发过程中的重要工具,它们帮助我们清晰地定义系统的需求和功能,建立用户与系统之间的桥梁,为后续的设计和实现提供了基础。通过理解用例、参与者和场景的概念,以及它们之间的关系,...
### 超市管理系统UML类图和用例图知识点详解 #### 1. 用例和用例图 ##### 1.1 什么是用例和用例图 用例是一种描述系统行为的方式,它主要从用户的视角出发,定义了系统应该具备的功能。一个用例通常包括了一系列...
3. **关系(Relationship)**:关系包括泛化(Generalization)、包含(Include)和扩展(Extend)。泛化关系意味着一个用例是另一个更具体用例的超集;包含关系表示一个用例可以包含其他用例的行为;扩展关系则表示...
用例图是统一建模语言(UML)中的一种图表,用于描述系统的功能和行为。用例图显示谁将是相关的用户、用户希望系统提供什么服务以及用户需要为系统提供的服务。用例图最常用来描述系统以及子系统。 二、用例图的...