[整理]UML用例中的包含、扩展、泛化关系的理解.
UML各种图详解
父用例通常是抽象的。
1一个类和一个接口不同:一个类可以有它形态的真实实例,然而一个接口必须至少有一个类来实现它。
在 UML 2 中,一个接口被认为是类建模元素的特殊化。
因此,接口就象类那样绘制,但是长方形的顶部区域也有文本“interface”。
2》UML 支持的可见性类型的标志3》多重值和它们的表示4》类图之间的关系有:泛化(继承),依赖,关联,聚合/组合。
1.聚合/组合聚合是一种特别类型的关联,用于描述“总体到局部”的关系。
在基本的聚合关系中,部分类的生命周期独立于整体类的生命周期。
举例来说,我们可以想象,车是一个整体实体,而车轮轮胎是整辆车的一部分。
轮胎可以在安置到车时的前几个星期被制造,并放置于仓库中。
在这个实例中,Wheel类实例清楚地独立地Car类实例而存在。
然而,有些情况下,部分类的生命周期并不独立于整体类的生命周期-- 这称为合成聚合。
举例来说,考虑公司与部门的关系。
公司和部门都建模成类,在公司存在之前,部门不能存在。
这里Department类的实例依赖于Company类的实例而存在。
·基本聚合(聚合)有聚合关系的关联指出,某个类是另外某个类的一部分。
在一个聚合关系中,子类实例可以比父类存在更长的时间。
为了表现一个聚合关系,你画一条从父类到部分类的实线,并在父类的关联末端画一个未填充棱形。
图中清楚的表明了类Car对象包含了另一类Wheel的4个实例,这两者在概念上是密不可分的,其中的一个类是另一个类的构成成分。
菱形表示“包含”,箭头表示被包含的对象,数字4表示包含的数目。
·组合聚合(组合)组合聚合关系是聚合关系的另一种形式,但是子类实例的生命周期依赖于父类实例的生命周期。
注意:组合关系如聚合关系一样绘制,不过这次菱形是被填充的。
2.依赖依赖可以说是要完成C5里的所有功能,一定要有C6的方法协助才行3.关联可以分为单向关联,双向关联双向关联:C1-C2:指双方都知道对方的存在,都可以调用对方的公共属性和方法。
UML用例图的扩展点与扩展用例讲解
UML用例图的扩展点与扩展用例讲解UML(Unified Modeling Language)是一种用于软件系统建模的标准化语言,它提供了一套丰富的图形化符号和规范,用于描述软件系统的结构、行为和交互。
其中,用例图是一种常用的建模工具,用于描述系统的功能需求和用户与系统之间的交互。
在用例图中,用例代表了系统的功能需求,用例之间的关系可以通过关联、包含和扩展等方式进行表示。
本文将重点讲解扩展点与扩展用例的概念及其在用例图中的应用。
一、扩展点的概念扩展点是指在原有用例的执行过程中,可以插入额外的功能或行为的特定位置。
它是用来定义系统在某个阶段或条件下是否可以执行扩展用例的标记点。
扩展点通常与原有用例的某个步骤或事件相关联。
扩展点的标记方式通常是在用例图中使用带有箭头的虚线表示,并在箭头上标注扩展用例的名称。
这样,当系统执行到该扩展点时,就可以根据特定的条件选择是否执行扩展用例。
二、扩展用例的概念扩展用例是指在特定的条件下,根据系统的需要,可以选择性地执行的用例。
它通常是对原有用例的功能进行扩展或增强,以满足某些特殊的需求。
扩展用例与原有用例之间的关系可以通过扩展关系来表示。
在用例图中,使用带有箭头的实线表示扩展关系,箭头指向扩展用例,并在箭头上标注扩展点的名称。
三、扩展点与扩展用例的应用扩展点与扩展用例的应用可以帮助系统设计者更好地理解系统的需求,并对系统进行更加灵活的设计。
通过定义扩展点和扩展用例,可以将系统的功能细化,并且在需要的时候选择性地引入额外的功能。
例如,假设我们正在设计一个电子商务系统,其中包含了一个购物车功能。
在购物车中,用户可以添加商品、修改数量、删除商品等操作。
我们可以将购物车的添加商品操作定义为一个扩展点,当用户添加商品时,系统可以根据特定的条件选择是否执行扩展用例。
在这个例子中,我们可以定义一个扩展用例为“优惠券使用”,当用户添加商品到购物车时,系统可以检查用户是否拥有可用的优惠券,并根据优惠券的规则进行相应的折扣计算。
简述uml用例间的关系
简述uml用例间的关系UML(Unified Modeling Language)是一种用于软件开发的建模语言,它提供了一种标准的图形化表示方法,用于描述系统的结构、行为和交互。
在UML中,用例图是一种常用的图形化表示方式,用于描述系统的功能需求和用户与系统之间的交互。
用例间的关系是指不同用例之间的相互关联和影响。
在UML中,用例间的关系有以下几种:1. 包含关系(Include):表示一个用例包含另一个用例的功能。
当一个用例需要借用其他用例的功能时,可以使用包含关系来表示。
例如,一个购物车用例可能包含了添加商品、移除商品和结算等子用例。
2. 扩展关系(Extend):表示一个用例可以在特定条件下扩展另一个用例的功能。
当一个用例的某个功能在特定条件下可以被扩展时,可以使用扩展关系来表示。
例如,一个支付用例可以在用户选择使用优惠券时扩展结算用例的功能。
3. 泛化关系(Generalization):表示一个用例是另一个用例的特殊情况或特化。
当一个用例继承了另一个用例的功能,并且在此基础上添加了新的功能时,可以使用泛化关系来表示。
例如,一个在线购物系统中的用户登录和游客购物两个用例可以通过泛化关系来表示,游客购物是用户登录的特殊情况。
4. 关联关系(Association):表示不同用例之间的关联和交互。
当一个用例需要与其他用例进行交互时,可以使用关联关系来表示。
例如,在一个社交网络系统中,用户发布动态和用户评论动态两个用例可以通过关联关系来表示。
5. 依赖关系(Dependency):表示一个用例依赖于另一个用例。
当一个用例的实现依赖于其他用例时,可以使用依赖关系来表示。
例如,在一个在线购物系统中,购物车结算用例依赖于查看购物车用例。
6. 一般化关系(Realization):表示一个用例实现了另一个用例的功能。
当一个用例实现了另一个用例定义的接口和行为时,可以使用一般化关系来表示。
例如,一个在线支付系统可以实现支付用例定义的支付接口和行为。
uml用例图中的包含、扩展、泛化关系
UML用例图中包含(include)、扩展(extend)和泛化(generalization)三种关系详解共性:都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
1、包含(include)包含关系:使用包含(Inclusion)用例来封装一组跨越多个用例的相似动作(行为片断),以便多个基(Base)用例复用。
基用例控制与包含用例的关系,以及被包含用例的事件流是否会插入到基用例的事件流中。
基用例可以依赖包含用例执行的结果,但是双方都不能访问对方的属性。
包含关系对典型的应用就是复用,也就是定义中说的情景。
但是有时当某用例的事件流过于复杂时,为了简化用例的描述,我们也可以把某一段事件流抽象成为一个被包含的用例;相反,用例划分太细时,也可以抽象出一个基用例,来包含这些细颗粒的用例。
这种情况类似于在过程设计语言中,将程序的某一段算法封装成一个子过程,然后再从主程序中调用这一子过程。
例如:业务中,总是存在着维护某某信息的功能,如果将它作为一个用例,那新建、编辑以及修改都要在用例详述中描述,过于复杂;如果分成新建用例、编辑用例和删除用例,则划分太细。
这时包含关系可以用来理清关系。
2、扩展(extend)扩展关系:将基用例中一段相对独立并且可选的动作,用扩展(Extension)用例加以封装,再让它从基用例中声明的扩展点(Extension Point)上进行扩展,从而使基用例行为更简练和目标更集中。
扩展用例为基用例添加新的行为。
扩展用例可以访问基用例的属性,因此它能根据基用例中扩展点的当前状态来判断是否执行自己。
但是扩展用例对基用例不可见。
对于一个扩展用例,可以在基用例上有几个扩展点。
例如,系统中允许用户对查询的结果进行导出、打印。
对于查询而言,能不能导出、打印查询都是一样的,导出、打印是不可见的。
导入、打印和查询相对独立,而且为查询添加了新行为。
用例的三种关系
用例的三种关系用例是软件开发中的重要组成部分,用于描述系统与用户之间的交互。
在用例分析的过程中,我们需要了解用例之间的关系,以便更好地理解系统功能和需求。
用例的关系可以分为三种:包含关系、扩展关系和泛化关系。
1. 包含关系(Include Relationship)包含关系表示一个用例可以包含另一个用例,被包含的用例是基础功能,被包含的用例所描述的场景是包含关系中包含用例的一部分。
包含关系可以用来提高用例的复用性和可维护性。
在用例图中,包含关系用带箭头的虚线表示。
举个例子,假设我们正在开发一个电子商务网站,其中一个用例是“用户下订单”,而另一个用例是“用户选择支付方式”。
用户下订单的过程中必须选择支付方式,所以“用户选择支付方式”这个用例可以被包含在“用户下订单”用例中。
通过包含关系,我们可以将这两个用例的共同部分提取出来形成一个独立的用例。
2. 扩展关系(Extend Relationship)扩展关系表示一个用例可以在特定条件下扩展另一个用例。
扩展关系描述了一个用例可以根据某种条件执行额外的步骤或者部分功能。
扩展关系可以用于处理非必要的但可能发生的情况。
在用例图中,扩展关系用带箭头的虚线表示。
举个例子,继续以电子商务网站为例,假设我们有一个基本的用例是“用户下订单”,而另一个用例是“用户使用优惠码”。
当用户选择使用优惠码的时候,我们可以通过扩展关系将“用户使用优惠码”这个用例扩展到“用户下订单”用例中。
这样,在完成基本的下订单操作后,系统将会检查是否有优惠码,并执行相应的优惠操作。
3. 泛化关系(Generalization Relationship)泛化关系表示一个用例可以作为另一个用例的一般形式。
泛化关系在用例间建立一种继承关系,用于描述用例之间的通用和特殊关系。
在用例图中,泛化关系用带箭头的实线表示。
举个例子,假设我们正在开发一个电子商务网站,其中有多种不同的用户角色,如客户、管理员和供应商。
用例间的关联(泛化-包含-扩展)
➢A extend B 表示B是A在系统某些情况下(特定条件)触发产 生的,B不是A中必须存在的部分,B可以单独存在 ➢B是对A在一些基本功能上具体的扩展(在A的扩展点处)
9
用例间的关系
➢Include 包含关系通常发生在多个用例中,有可以提取出来 的公共部分(就象提取公因式一样) ➢例如 UseCaseA 中包括了 a 和 b 两个流程,而 UseCaseC 中 包含了 c 和 b 两个流程。为了提高复用性,可以把 b 提取出来, 形成另一个用例 UseCaseB,此时,UseCaseA include UseCaseB,UseCaseC 也 include UseCaseB。 ➢当有 include 关系时,被 include 的用例通常会被两个以上的 其他用例 include(否则就不需要提取出来了)
10
用例间的关系
➢Extend 关系:假设 UseCaseA 的功能描述为“发送一条通 知”,可是,发送通知的方式可能有许多种(例如通过邮件发 送、通过短信发送等)。在需求分析阶段,可能无法明确到底 有多少种方式, 在用例分析阶段,UseCaseA 需要留出扩展接 口,然后把已知的发送方式作为扩展用例给出,例如 UseCaseB 是“通过短信发送”,而 UseCaseC 是“通过邮件 发送”,此时,UseCaseB 和 UseCaseC extend 了 UseCaseA, 表现为两根虚线,箭头指向 UseCaseA
11
用例间的关系
12
用例间的关系
错!
13
用例间的关系
➢销户:因为销户必需先进行账户结算,所以这里用include ➢停机提醒:有两个可选项,短信提醒和邮件提醒,所以用extend
用例之间的关系
例子
一个汽车租赁系统用例图的部分内容。在此,基本
用例是“还车”,扩展用例是“交纳罚金”。如果 一切顺利汽车可以被归还,那么执行“还车”用例 即可。但是如果超过了还车的时间或汽车受损,按 照规定客户要交纳一定的罚金,这时就不能执行提 供的常规动作。若研讨修改用例“还车”,势必会 增加系统的复杂性,因此可以在用例“还车”中增 加扩展点,即特定条件为超时或损坏,如果满足条 件,将执行扩展用例“交纳罚金”,这样显然可以 使系统更容易被理解。
用例之间的关系
在画用例图的时候,理清用例之间的关系是重 点。用例的关系有泛化(generalization)、扩展 (extend)和包含(include)。其中include和 extend最易混淆。 使用关系uses(UML1.2以后已经不再使用此关 系) 下面我们结合实例彻底理清三者的关系。
基本概念
包含(include)
include为包含关系,当两个或多个用例中共用一组
相同的动作,这时可以将这组相同的动作抽出来作 为一个独立的子用例,供多个基用例所共享。因为 子用例被抽出,基用例并非一个完整的用例,所以 include关系中的基用例必须和子用例一起使用才 够完整,子用例也必然被执行。include关系在用例 图中使用带箭头的虚线表示(在线上标注 <<include>>),箭头从基用例指向子用例。
泛化关系是一种继承关系,子用例将继承基
用例的所有行为,关系和通信关系,也就是 说在任何使用基用例的地方都可以用子用例 来代替。泛化关系在用例图中使用空心的箭 头表示,箭头方向从子用例指向基用例。
在用例泛化中,子用例表示父用例的特殊形式,子用例继承了 父用例的行为和属性,也可以增加新的行为和属性或覆盖父用 例中的行为。
uml用例之间的关系
uml用例之间的关系UML(Unified Modeling Language)是一种用于软件系统建模的标准化语言,它可以通过图形化的方式描述系统的结构、行为和交互关系。
在UML中,用例是对系统功能的一种描述,用例之间的关系充满着指导和解释作用。
下面将具体介绍几种常见的用例之间的关系。
1. 包含关系(Includes):包含关系是一种用例之间的关系,表示一个用例包含了另一个用例的行为。
通常情况下,一个用例(被包含用例)在执行过程中会调用另一个用例(包含用例)来完成一部分功能。
例如,在一个购物系统中,用户下单时可能会调用一个包含了支付用例的用例。
2. 扩展关系(Extends):扩展关系也是一种用例之间的关系,表示一个用例可以在另一个用例的基础上进行扩展。
扩展用例在被扩展用例中定义了一些额外的行为,这些行为可以根据系统需求的变化来进行扩展。
例如,在一个社交网络系统中,用户发表动态的用例可以根据用户需求扩展为带有图片上传功能的动态。
3. 泛化关系(Generalization):泛化关系是一种用于表示继承关系的关系,用于描述一组具有共同特征的用例之间的关系。
泛化用例通常描述了一组具有相似功能的用例,并从中提取出了共同的特征,作为基础用例。
例如,在一个银行系统中,取款用例和存款用例可以被抽象为基本用例-交易用例,其共同的特征是对用户账户进行操作。
4. 关联关系(Association):关联关系是一种用例之间的关系,表示两个用例之间存在某种关联或依赖关系。
这种关联关系可以是双向的,也可以是单向的。
例如,在一个电子商务系统中,用户注册和登录用例可能存在关联关系,因为用户需要先注册才能登录系统。
综上所述,UML用例之间的关系对于系统分析与设计非常重要。
通过对用例之间的关系进行建模,可以帮助系统开发人员更好地理解系统的功能和行为,并指导团队的开发工作。
不同的用例关系表示了不同的依赖和交互方式,开发人员可以根据具体的需求情况选择适合的关系建模,以实现系统的需求和目标。
用例之间的三种关系
用例之间的三种关系
用例是指为了验证某种特定目的或功能而实际执行的一组任务或
活动。
在软件工程中,用例可以用来描述需求,是需求分析的一个重要输入。
在需求分析阶段,用例描述了系统必须满足的所有功能和行为,以确保系统的正确性和稳定性。
用例之间的关系有三种:包含、扩展和泛化。
1.包含关系:一个用例可以包含在另一个用例中,例如一个用例可以包含在另一个用例的实现中。
这种关系通常用于描述用例之间的依赖关系,即一个用例的实现依赖于另一个用例的实现。
2.扩展关系:一个用例可以扩展另一个用例的行为,即一个用例的行为可以在另一个用例的基础上进行扩展。
例如,一个用例可以扩展另一个用例的功能,或者一个用例可以在另一个用例的基础上添加新的行为。
3.泛化关系:一个用例可以泛化到其他用例的行为中,即一个用例的行为可以适用于其他用例的情况。
例如,一个用例可以泛化到其他用例的功能中,或者一个用例可以在其他用例的基础上进行修改和扩展。
总之,用例是软件需求分析中的重要输入,用例之间的关系可以描述用例之间的依赖关系和扩展关系。
通过正确理解用例之间的关系,可以帮助开发人员更好地理解系统的需求,并确保系统的正确性和稳定性。
用例间的关联(泛化-包含-扩展)
用例间的关系
12
用例间➢销户:因为销户必需先进行账户结算,所以这里用include ➢停机提醒:有两个可选项,短信提醒和邮件提醒,所以用extend
14
用例间的关联
(泛化/包含/扩展)
§3.2.2 用例图的组成
3)用例与用例的关联
用例之间也可存在关联。这些关联包括: •泛化关联 •包含关联 •扩展关联
此外,系统分析员也可以利用UML的扩充机制自定义用例 的关联。
2
用例间的关系
用例与用例的泛化关联用来表示一般用例与特殊用例的泛化 关系。在UML图中,使用带空心三角箭头的实线表示。如下图所 示:
(1)B通常是A和C 中共同操作部分抽象出的部分 (2)B是A的子过程为了避免太复杂单独抽象出来的部分
➢A extend B 表示B是A在系统某些情况下(特定条件)触发产 生的,B不是A中必须存在的部分,B可以单独存在 ➢B是对A在一些基本功能上具体的扩展(在A的扩展点处)
9
用例间的关系
➢Include 包含关系通常发生在多个用例中,有可以提取出来 的公共部分(就象提取公因式一样) ➢例如 UseCaseA 中包括了 a 和 b 两个流程,而 UseCaseC 中 包含了 c 和 b 两个流程。为了提高复用性,可以把 b 提取出来, 形成另一个用例 UseCaseB,此时,UseCaseA include UseCaseB,UseCaseC 也 include UseCaseB。 ➢当有 include 关系时,被 include 的用例通常会被两个以上的 其他用例 include(否则就不需要提取出来了)
3
用例间的关系
用例与用例的包含关联用来表示一个用例中重用另一个用 例中的步骤.在UML图中,使用带虚线箭头表示,并在线上标有 构造型<<include>>。如下图所示:
UML用例图中的关系
UML用例图中的关系用例之间的关系做一个总结。
1、关联关系(association):用带箭头的实线表示,由参与者指向用例。
关联关系是指参与者与用例之间的关系,是参与者和用例之间的通信。
一个参与者可以关联多个用例,一个用例可以关联多个参与者。
但是每一对参与者和用例之间(即一条连线上)的通信必须是唯一的,否则则存在可以合并的参与者或者用例。
2、泛化关系(dependency):用带空心三角形的实线表示,由子级指向父级。
泛化关系是参与者于参与者之间或者用例于用例之间的关系。
泛化即继承关系,子用例(子参与者)继承了父用例(父参与者)的一切行为和通信。
同时还可以增加属于自己独有的行为和通信。
以机房收费系统中的三个参与者为例。
操作员继承了一般用户的所有功能,同时增加了充值、工作记录查询等功能。
而管理员则继承了操作员的一切功能,同时增加了结账和报表生成等功能。
用例图如下:3、包含关系(include):用带箭头的虚线和版型(include)表示,由基本用例指向被包含用例。
包含关系是用例之间的关系。
所谓的包含关系是指当一个用例需要以另一个用例的执行为前提才能执行时,这两个用例间的关系。
即一个用例不能被独立执行,随着另一个用例的执行而执行,也随着另一个用例的消亡而消亡。
以机房收费系统中的结账功能为例,如下图:在上图中结账用例和汇总退还金额用例之间即包含关系。
如果结账用例不执行时就无法执行汇总退还金额用例,而结账用例结束那么汇总用例也随之结束。
4、扩展关系(extend):用带箭头的虚线和版型(extend)表示,右基本用例指向扩展用例。
扩展关系也是用例之间的关系。
它指的是,当一个用例执行时出现某种特定的条件时,激活另一个用例。
这里的一定条件称之为扩展点,被激活的用例称之为扩展用例。
以机房收费系统中,上机时余额不足为例,如下图:上图中,上机用例执行时若发现学生卡号中的余额小于最低余额时则直接转入充值用例,但是充值用例也可以单独被执行。
UML用例中的包含、扩展、泛化关系的理解
UML用例中的包含、扩展、泛化关系的理解在用例关系中有有三种关系,一是包括,"include" 一是扩展"extend"一是泛化,当然还有最基本的关系,“关联”.其中,包含关系:包含关系用于将部分工作流程分离出去,对这部分工作流程来说,基本用例只取决于结果,与获得结果的方法无关。
如果这种分离可以简化对基本用例的理解(隐藏详细的行为),或者可以在其他基本用例中复用被分离的行为,您就可以将这部分工作流程分离出去。
基本用例通过包含关系连接到包含用例。
包含用例总是抽象的。
它描述在执行基本用例的用例实例中插入的行为段。
基本用例可控制与包含用例的关系,并可依赖于执行包含用例所得的结果,但是基本用例和包含用例都不能访问对方的属性。
从这种意义上来讲,包含用例是被封装的,它代表可以在各种不同的用例中复用的行为。
包含关系用于:(1)从基本用例中分解出来这种的行为:它对于了解基本用例的主要目的不是必需的,只有它的结果才比较重要。
(2)分解出两个或者多个用例所共有的行为。
扩展关系:扩展关系将扩展用例与基本用例连接了起来,通过在基本用例中引用扩展点,可以定义在基本用例的哪些位置插入扩展用例,扩展用例通常是抽象的,但是不是必须抽象。
扩展的目的在于:(1)表明用例的某一部分是可选的(或者可能可选)的系统行为。
这样,你就可以将模型中的可选行为和必选行为分开。
(2)表明只有在特定条件下(有时候是异常情况下)才执行的分支流,如触发警报。
(3)表明可能有一组行为段,其中的一个或者多个段可以在基本用例中的扩展点处插入。
所插入的行为段(以及插入的顺序)将取决于在执行基本用例时与主角进行的交互。
扩展是有条件的,它是否执行取决于在执行基本用例时所发生的事件。
基本用例并不控件执行扩展的条件,这些条件在扩展关系中进行说明。
扩展用例可以访问和修改基本用例的属性。
但是基本用例看到到扩展用例,也无法访问它们的属性。
UML用例图中的包含、扩展、泛化关系
UML用例图中包含(include)、扩展(extend)和泛化(generalization)三种关系详解共性:都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
1、包含(include)包含关系:使用包含(Inclusion)用例来封装一组跨越多个用例的相似动作(行为片断),以便多个基(Base)用例复用。
基用例控制与包含用例的关系,以及被包含用例的事件流是否会插入到基用例的事件流中。
基用例可以依赖包含用例执行的结果,但是双方都不能访问对方的属性。
包含关系对典型的应用就是复用,也就是定义中说的情景。
但是有时当某用例的事件流过于复杂时,为了简化用例的描述,我们也可以把某一段事件流抽象成为一个被包含的用例;相反,用例划分太细时,也可以抽象出一个基用例,来包含这些细颗粒的用例。
这种情况类似于在过程设计语言中,将程序的某一段算法封装成一个子过程,然后再从主程序中调用这一子过程。
例如:业务中,总是存在着维护某某信息的功能,如果将它作为一个用例,那新建、编辑以及修改都要在用例详述中描述,过于复杂;如果分成新建用例、编辑用例和删除用例,则划分太细。
这时包含关系可以用来理清关系。
2、扩展(extend)扩展关系:将基用例中一段相对独立并且可选的动作,用扩展(Extension)用例加以封装,再让它从基用例中声明的扩展点(Extension Point)上进行扩展,从而使基用例行为更简练和目标更集中。
扩展用例为基用例添加新的行为。
扩展用例可以访问基用例的属性,因此它能根据基用例中扩展点的当前状态来判断是否执行自己。
但是扩展用例对基用例不可见。
对于一个扩展用例,可以在基用例上有几个扩展点。
例如,系统中允许用户对查询的结果进行导出、打印。
对于查询而言,能不能导出、打印查询都是一样的,导出、打印是不可见的。
导入、打印和查询相对独立,而且为查询添加了新行为。
泛化关系、拓展关系、包含关系的概念
泛化关系、拓展关系、包含关系的概念
泛化关系、拓展关系和包含关系是三种常见的概念关系,广泛应用于语义网络和图论中。
1. 泛化关系
泛化关系是指在一个节点周围,围绕着该节点及其子节点展开的一系列关系。
一个节点的泛化关系可以看作是该节点及其子节点之间的关系的扩展。
一个节点的泛化关系的集合可以用该节点的子节点集合表示。
例如,在社交网络中,一个人的社交关系可以看作是这个人及其朋友、家人、同事等的泛化关系。
泛化关系可以帮助我们更好地理解社交网络中的节点和边之间的关系。
2. 拓展关系
拓展关系是指一个节点与其子节点之间的关系,通过连接另一个节点来扩展这些关系。
拓展关系通常是基于连接关系的,连接关系可以看作是拓展关系的实现方式。
例如,在社交网络中,一个人的社交关系可以通过添加新的朋友、家人、同事等节点来扩展。
这些新节点可以看作是拓展关系的实现方式。
3. 包含关系
包含关系是指一个节点包含其子节点的关系。
一个节点的包含关系可以看作是该节点与其子节点之间的连接关系。
一个节点可以有多个子节点,这些子节点可以组成一个包含关系。
例如,在社交网络中,一个人的社交关系可以看作是由这个人及其朋友、家人、同事等节点组成的包含关系。
一个节点的子节点可以是该节点的朋友、家人、同
事等,这些子节点可以组成一个包含关系。
这三种关系可以帮助我们更好地理解语义网络和图论中的节点和边之间的关系。
UML用例图中泛化、扩展、包括
UML⽤例图中泛化、扩展、包括在画⽤例图的时候,理清⽤例之间的关系是重点。
⽤例的关系有泛化(generalization)、扩展(extend)和包含(include)。
其中include和extend 最易混淆。
下⾯我们结合实例彻底理清三者的关系。
基本概念⽤例图(Use Case Diagram):⽤例图显⽰谁是相关的⽤户,⽤户希望系统提供什么服务(⽤例),以及⽤例之间的关系图。
⽤例图主要的作⽤是获取需求、指导测试。
⽤例图的4个基本组件:参与者(Actor)、⽤例(Use Case)、关系(Relationship)和系统。
泛化(generalization):泛化关系是⼀种继承关系,⼦⽤例将继承基⽤例的所有⾏为,关系和通信关系,也就是说在任何使⽤基⽤例的地⽅都可以⽤⼦⽤例来代替。
泛化关系在⽤例图中使⽤空⼼的箭头表⽰,箭头⽅向从⼦⽤例指向基⽤例。
扩展(extend): extend关系是对基⽤例的扩展,基⽤例是⼀个完整的⽤例,即使没有⼦⽤例的参与,也可以完成⼀个完整的功能。
extend的基⽤例中将存在⼀个扩展点,只有当扩展点被激活时,⼦⽤例才会被执⾏。
extend关系在⽤例图中使⽤带箭头的虚线表⽰(在线上标注<<extend>>),箭头从⼦⽤例指向基⽤例。
包含(include): include为包含关系,当两个或多个⽤例中共⽤⼀组相同的动作,这时可以将这组相同的动作抽出来作为⼀个独⽴的⼦⽤例,供多个基⽤例所共享。
因为⼦⽤例被抽出,基⽤例并⾮⼀个完整的⽤例,所以include关系中的基⽤例必须和⼦⽤例⼀起使⽤才够完整,⼦⽤例也必然被执⾏。
include关系在⽤例图中使⽤带箭头的虚线表⽰(在线上标注<<include>>),箭头从基⽤例指向⼦⽤例。
实例需求场景联通客户响应OSS。
系统有故障单、业务开通、资源核查、割接、业务重保、⽹络品质性能等功能模块。
泛化关系、拓展关系、包含关系的概念
泛化关系、拓展关系、包含关系的概念
泛化关系:泛化关系是指一个类(父类)与其他一个或多个类(子类)之间的关系。
父类提供了一组通用的属性和方法,子类可以继承并扩展这些属性和方法,同时还可以定义自己独有的属性和方法。
泛化关系体现了面向对象编程语言中的继承特性。
拓展关系:拓展关系是指一个类(扩展类)通过继承另一个类(被扩展类)来扩展属性和方法。
扩展类可以在原有类的基础上增加新的属性和方法,同时还可以重写继承的属性和方法。
拓展关系通常用于对已存在的类进行功能扩展,以满足特定需求,而不需要修改原有类的代码。
包含关系:包含关系是指一个类(容器类)包含另一个类(成员类)作为其属性或成员变量的关系。
容器类可以通过实例化成员类的对象来使用成员类中定义的属性和方法。
包含关系通常用于将多个类组合在一起形成更复杂的类,以实现更高层次的功能。
可以通过包含关系来实现代码的模块化和复用。
UML用例间包含关系与泛化关系的比较与分析
2 包含关系与泛化关系的比较 包含关系和泛化关系均属于用例之间的关系,并且基本表
现形式都是从现有用例的事件流中抽取出共有部分,将其作为一 个单独的用例,从而达到复用现有用例的行为,并提高模型可维 护性的目的。但两者在实际使用过程中又存在着显著的区别。
在用例图的建模过程中,一般有两种情况需要使用到包 含关系。第一种最为常用,在对用例的事件流进行描述的过 程中,若发现多个用例同时使用到同一段行为,则可将这段共 同的行为单独抽象成为一个用例,然后建立两者之间的包含关 系,从而实现重用并简化事件流描述的目的。
以自主点餐系统为例,客户可以进行“预约餐台”、“下 单点餐”、“支付结算”和“发表评价”四个操作,所有操作 均需在“登录系统”后方可完成。根据描述,“登录系统”为 多个用例的共同行为,可将其抽象出来,成为一个新的用例, 并建立其与4个基础用例之间的包含关系。关系一旦创建,这4 个基础用例在用例规约的事件流描述中可直接对“登录系统” 用例的事件流进行引用,避免了对公共行为的重复描述,提高 了模型的可维护性。
1.2 泛化关系 用例间的泛化关系将特化的用例与一般化的用例联系起 来,这两个用例分别被称为、行为和关系,并且可以添加、覆盖或者改变 继承的行为。 在对用例的事件流进行描述的过程中,发现两个或者多个
用例在行为、结构和目的方面存在共性时,可以新建一个一般 化的用例用于描述这些共有部分和一般过程,然后建立特化用 例和一般化用例之间的泛化关系,从而实现重用并简化事件流 描述的目的。
在自主点餐系统的功能性需求中,有这样一段描述,“支 付结算”主要包括“支付宝结算”和“会员卡结算”两种方 式。经过分析发现,“支付宝结算”和“会员卡结算”两个用 例在行为、结构和目的方面都存在共性,都属于“支付结算” 的特殊方式,因此可将其抽象为父用例,两种代表具体支付方 式的用例抽象为子用例,建立泛化关系,并且箭头方向从子用 例指向父用例。
UML-用例关联
UML-⽤例关联
1、⽤例关联:就是各个⽤例之间的关系,分3种关系分别是:包含关系、扩展关系、泛化关系。
2、包含关系
1)、⽰例
2)、使⽤场景
A、⽤例在其他⽤例中重复使⽤
B、⽤例⾮常复杂冗长,将其分解为⼦单元便于理解。
3、术语
具体⽤例:由参与者发起,完成了所期望的完整⾏为。
如处理销售。
抽象⽤例:其他⽤例的⼦功能实现。
如处理信⽤卡⽀付,他不能独⽴存在,只能是其他⽤例的⼀部分。
基础⽤例:包含其他⽤例的⽤例,或者被其他⽤例扩展或者泛化的⽤例。
如:处理销售⽤例包含处理信⽤卡⽀付⽤例,因此处理销售是基础⽤例。
附加⽤例:被其他⽤例包含的⽤例,或者扩展、泛化其他⽤例的⽤例。
如:处理信⽤卡⽀付⽤例被处理销售⽤例包含,因此处理信⽤卡⽀付⽤例就是附加⽤例。
附加⽤例通常是抽象⽤例。
基础⽤例通常是具体⽤例。
如下图:
4、扩展关系
如果某个⽤例⽂本因为某些原因不能被修改,但是,业务要修改,怎么办?答:创建扩展或附加⽤例,并且在其中指明扩展点,即:在何处、何种条件下触发扩展⽤例。
5、泛化关系
增加复杂度。
可选。
6、⽰例
专家建议,保持事物简单、优先使⽤包含关系。
1)、包含关系
2)、扩展关系。
uml用例图笔记
UML用例图
用例图包含6个元素:
1.参与者(Actor)
2.用例(Use Case)即一个动作;
3.关联关系(Association)
4.包含关系(Include)
5.扩展关系(Extend)
6.泛化关系(Generalization)
用例之间的关系包括包含关系、扩展关系、泛化关系。
1、关联关系
参与者与用例的关系
2、包含关系
若用例A包含用例B,执行A肯定是要执行B的(路径正常情况下)箭头指向子B动作
例:若要网上订购则肯定需要填写电子表格
3、扩展关系
若用例A在某个条件下执行用例B的动作
则用例A扩展用例B
若用例A和用例B是泛化关系(箭头指向A)
例:在还车时只有在超出期限时才需要交纳罚金
4、泛化关系
若AB是泛化关系,则A是父代B是子代。
B继承了A的所有动作。
例:电话预订酒店和网上预订酒店是在订酒店的子类;其中前两者肯定继承了订酒店的所有动作;
注释:
包含和扩展都是用虚线和箭头表示,两者用extend和include来区分;
泛化是用三角形箭头和实现表示;
参与者之间也有泛化的关系(即父子关系);。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
UML用例中的包含、扩展、泛化关系的理解收藏
在用例关系中有有三种关系,一是包括,"include" 一是扩展"extend"一是泛化,当然还有最基本的关系,“关联”.
其中,包含关系:
包含关系用于将部分工作流程分离出去,对这部分工作流程来说,基本用例只取决于结果,与获得结果的方法无关。
如果这种分离可以简化对基本用例的理解(隐藏详细的行为),或者可以在其他基本用例中复用被分离的行为,您就可以将这部分工作流程分离出去。
基本用例通过包含关系连接到包含用例。
包含用例总是抽象的。
它描述在执行基本用例的用例实例中插入的行为段。
基本用例可控制与包含用例的关系,并可依赖于执行包含用例所得的结果,但是基本用例和包含用例都不能访问对方的属性。
从这种意义上来讲,包含用例是被封装的,它代表可以在各种不同的用例中复用的行为。
包含关系用于:(1)从基本用例中分解出来这种的行为:它对于了解基本用例的主要目的不是必需的,只有它的结果才比较重要。
(2)分解出两个或者多个用例所共有的行为。
扩展关系:
扩展关系将扩展用例与基本用例连接了起来,通过在基本用例中引用扩展点,可以定义在基本用例的哪些位置插入扩展用例,扩展用例通常是抽象的,但是不是必须抽象。
扩展的目的在于:(1)表明用例的某一部分是可选的(或者可能可选)的系统行为。
这样,你就可以将模型中的可选行为和必选行为分开。
(2)表明只有在特定条件下(有时候是异
常情况下)才执行的分支流,如触发警报。
(3)表明可能有一组行为段,其中的一个或者多个段可以在基本用例中的扩展点处插入。
所插入的行为段(以及插入的顺序)将取决于在执行基本用例时与主角进行的交互。
扩展是有条件的,它是否执行取决于在执行基本用例时所发生的事件。
基本用例并不控件执行扩展的条件,这些条件在扩展关系中进行说明。
扩展用例可以访问和修改基本用例的属性。
但是基本用例看到到扩展用例,也无法访问它们的属性。
扩展用例以隐含的方式修改基本用例。
也可以说,基本用例定义了可以在其中添加扩展用例的模块化的框架,但是基本用例看不见特定的扩展用例。
基本用例自身应该是完整的,即基本用例应该是可理解并且有意义的,而不必引用任何扩展用例。
但是基本用例并不独立于扩展用例,因为如果无法遵循扩展用例,就不能执行基本用例。
泛化关系:用例的泛化关系是指一种从子用例到父用例的关系,它指定了子用例如何特化父用例的所有特征和行为。
父用例可以特化形成一个或者多个子用例,这些子用例代表了父用例比较特殊的形式。
尽管在大多数情况下父用例是抽象的,但是无论是父用例还是子用例这两者都不要求一定抽象。
子用例继承父用例的所有结构、行为和关系。
同一父用例的子用例都是该父用例的特例。
这就是可适用于用用例的泛化关系。
当你发现两个或者多用例在行为,结构和目的方面存在共性时,就可以使用泛化关系。
这种情况发生时,你可以用一个新的、通常也是抽象的用例来描述这些共有部分,该用例随后被子用例特化。
?。