需求中如何画用例图
UML用例图
用例图主要用来图示化系统的主事件流程,它主要用来描述客户的需求,即用户希望系统具备的完成一定功能的动作,通俗地理解用例就是软件的功能模块,所以是设计系统分析阶段的起点,设计人员根据客户的需求来创建和解释用例图,用来描述软件应具备哪些功能模块以及这些模块之间的调用关系,用例图包含了用例和参与者,用例之间用关联来连接以求把系统的整个结构和功能反映给非技术人员(通常是软件的用户),对应的是软件的结构和功能分解。
用例是从系统外部可见的行为,是系统为某一个或几个参与者(Actor)提供的一段完整的服务。从原则上来讲,用例之间都是独立、并列的,它们之间并不存在着包含从属关系。但是为了体现一些用例之间的业务关系,提高可维护性和一致性,用例之间可以抽象出包含(include)、扩展(extend)和泛(generalization)几种关系。
共性:都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
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提供服务,但用例提供服务的方式可分为间接和直接两种,依据于此,泛化中的子用例提供的是直接服务,而包含中的被包含用例提供的是间接服务。同样,扩展用例提供的也是直接服务,但扩展用例的发生是有条件的。
另外一点需要提及的是:泛化中的子用例和扩展中的扩展用例均可以作为基本用例事件的备选择流而存在。
分享到:
相关推荐
用例图是统一建模语言(UML)中的一种图表,用于描绘系统中的参与者(Actor)与用例(Use Case)之间的关系,表达系统功能需求和参与者之间的交互。它并不是简单的功能或菜单项的列表,而是以故事的形式描述参与者...
软件设计过程中画用例图的步骤 在软件设计需求分析阶段,画用例图是一个非常重要的步骤。用例图(Use Case Diagram)是描述人们如何使用一个系统的图表,它包含六个元素:参与者(Actor)、用例(Use Case)、关联...
在用例图中,参与者通常用简笔画的人物符号表示,下面会标注参与者的名字。 - **用例(Use Case)**:描述了一组动作序列,当这些动作被执行时会产生一个对参与者有价值的结果。在图中,用例通常用椭圆形表示,下方...
在用例图中,常见的元素包括: - 参与者(Actors):通常代表用户或其他系统,是使用系统功能的实体。 - 用例(Use Cases):代表系统能提供的一个具体的功能。 - 关联(Associations):连接参与者和用例,表示...
在用例图中,我们使用UML对网上购物系统进行建模,了解到系统中的用例和类,以及各个对象间的关系。用例图是UML中的一个重要组成部分,它描述了系统中的用例和它们之间的关系。通过用例图,我们可以更好地理解系统的...
在用例图中,主要元素包括参与者(Actor)、用例(Use Case)和它们之间的关系,如关联(Association)、包含(Include)和扩展(Extend)。通过用例图,我们可以直观地了解系统的主要功能和不同用户角色的行为。 ...
管理员用例图详细画出了管理员权限及流程用例图
在电子商务领域,用例图(Use Case Diagram)是一种重要的需求分析工具,它通过图形化的方式描绘了系统的主要参与者(Actor)以及他们与系统之间的交互关系。在这个名为“电子商务网站用例图”的案例中,我们将深入...
在用例图中,有两个重要的概念:参与者(Actor)和用例(UseCase)。 * 参与者(Actor):是指在系统外部与系统直接交互的人或事物。需要注意的是,参与者是角色(role)而不是具体的人,它代表了参与者在与系统打...
其中,用例图是UML中最常用的视图之一,用于描述系统的功能需求,展示系统与外部参与者之间的交互。本文将详细介绍如何使用Rational Rose这一强大的建模工具绘制用例图。 #### 准备工作 在开始绘制用例图之前,确保...
在画用例图的时候,理清用例之间的关系是重点。用例的关系有泛化(generalization)、扩展(extend)和包含(include)。其中include和extend最易混淆。下面我们结合实例彻底理清三者的关系。基本概念用例图...
用例图(Use Case Diagram)是 UML 中的一种静态模型,它描述的是系统的功能需求,展示了系统与外部参与者之间的交互关系。用例图由参与者、用例和关系组成。参与者是系统的外部用户或其他系统,例如,用户、管理员...
用例图是一种重要的需求分析工具,主要用于描述系统的外部可见行为以及不同角色与系统交互的方式。它能够清晰地展示系统的功能需求,帮助开发者理解用户的需求,并且便于进行后续的设计与实现。 #### 二、Rational ...
在用例图中,有以下几个关键元素: - **参与者(Actor)**: 表示与系统交互的外部实体,如用户、硬件设备或外部系统。 - **用例(Use Case)**: 描述了系统为参与者提供的一系列服务或功能。 - **关联关系...
用例图是系统分析中常用的一种建模手段,它清晰地描绘了系统的主要功能及其与参与者的交互关系。本文将对图书管理系统中的主要用例进行详细描述,帮助初学者理解其工作原理。 1. 登录用例: - 参与者:图书馆工作...
在软件工程网上图书销售系统的用例图中,我们可以画出三个矩形,分别表示非注册用户、注册用户和管理员。然后,我们可以画出多个椭圆形,分别表示搜索商品、下订单、查看修改订单、进行注册、查看商品信息、修改商品...
通过构建这样的用例图,可以清晰地展示物流公司的业务流程,帮助开发团队理解需求,设计系统架构,并作为后续系统开发、测试和维护的依据。因此,掌握用例图的创建和理解是软件工程师必备的技能之一。在实际工作中,...
### 二、Rational Rose工具介绍及其在绘制用例图中的应用 #### 1. Rational Rose简介 Rational Rose是一款由IBM开发的可视化建模工具,它支持多种UML模型图的绘制,包括用例图、类图、序列图等。Rational Rose不仅...