转自:http://developer.51cto.com/art/201007/209079.htm
本文和大家重点讨论一下UML用例图实例的应用,UML用例图包含了用例和参与者,用例之间用关联来连接以求把系统的整个结构和功能反映给非技术人员(通常是软件的用户),对应的是软件的结构和功能分解。
UML用例图
用例图主要用来图示化系统的主事件流程,它主要用来描述客户的需求,即用户希望系统具备的完成一定功能的动作,通俗地理解用例就是软件的功能模块,所以是设计系统分析阶段的起点,设计人员根据客户的需求来创建和解释用例图,用来描述软件应具备哪些功能模块以及这些模块之间的调用关系,UML用例图包含了用例和参与者,用例之间用关联来连接以求把系统的整个结构和功能反映给非技术人员(通常是软件的用户),对应的是软件的结构和功能分解。
用例是从系统外部可见的行为,是系统为某一个或几个参与者(Actor)提供的一段完整的服务。从原则上来讲,用例之间都是独立、并列的,它们之间并不存在着包含从属关系。但是为了体现一些用例之间的业务关系,提高可维护性和一致性,用例之间可以抽象出包含(include)、扩展(extend)和泛(generalization)几种关系。
共性:都是从现有的用例中抽取出公共的那部分信息,作为一个单独的用例,然后通后过不同的方法来重用这个公共的用例,以减少模型维护的工作量。
1、包含(include)
包含关系:使用包含(Inclusion)用例来封装一组跨越多个用例的相似动作(行为片断),以便多个基(Base)用例复用。基用例控制与包含用例的关系,以及被包含用例的事件流是否会插入到基用例的事件流中。基用例可以依赖包含用例执行的结果,但是双方都不能访问对方的属性。
UML用例图中包含关系对典型的应用就是复用,也就是定义中说的情景。但是有时当某用例的事件流过于复杂时,为了简化用例的描述,我们也可以把某一段事件流抽象成为一个被包含的用例;相反,用例划分太细时,也可以抽象出一个基用例,来包含这些细颗粒的用例。这种情况类似于在过程设计语言中,将程序的某一段算法封装成一个子过程,然后再从主程序中调用这一子过程。
例如:业务中,总是存在着维护某某信息的功能,如果将它作为一个用例,那新建、编辑以及修改都要在用例详述中描述,过于复杂;如果分成新建用例、编辑用例和删除用例,则划分太细。这时包含关系可以用来理清关系。
2、扩展(extend)
扩展关系:将基用例中一段相对独立并且可选的动作,用扩展(Extension)用例加以封装,再让它从基用例中声明的扩展点(ExtensionPoint)上进行扩展,从而使基用例行为更简练和目标更集中。UML用例图中扩展用例为基用例添加新的行为。扩展用例可以访问基用例的属性,因此它能根据基用例中扩展点的当前状态来判断是否执行自己。但是扩展用例对基用例不可见。
对于一个扩展用例,可以在基用例上有几个扩展点。
例如,系统中允许用户对查询的结果进行导出、打印。对于查询而言,能不能导出、打印查询都是一样的,导出、打印是不可见的。导入、打印和查询相对独立,而且为查询添加了新行为。因此可以采用扩展关系来描述:
3、泛化(generalization)
UML用例图中泛化关系:子用例和父用例相似,但表现出更特别的行为;子用例将继承父用例的所有结构、行为和关系。子用例可以使用父用例的一段行为,也可以重载它。父用例通常是抽象的。在实际应用中很少使用泛化关系,子用例中的特殊行为都可以作为父用例中的备选流存在。
例如,业务中可能存在许多需要部门领导审批的事情,但是领导审批的流程是很相似的,这时可以做成泛化关系表示:
上面是我参考的一篇文章,觉得将三种关系的区别讲得很清晰,在此基础上结合自己的系统,对项目(在线购物系统)的用例做了整体的描绘。
分享到:
相关推荐
《UML用例图在超时管理系统中的应用与解析》 UML(统一建模语言)是软件开发中的一种标准化建模工具,它为系统分析和设计提供了图形化的表示方式。其中,用例图(Use Case Diagram)是UML的重要组成部分,它用于...
《UML用例图实例讲解》 UML(统一建模语言)是软件开发中用于可视化、构建和文档化系统模型的重要工具。其中,用例图(Use Case Diagram)是UML的一种静态视图,主要用于描绘系统的主要角色、用例以及它们之间的...
2. **用例图**:用例图展示了系统与用户或外部实体之间的交互,通过“参与者”和“用例”来描绘系统功能需求。它是了解系统业务流程的起点,有助于确定系统边界和主要功能。 3. **类图**:类图是UML中用于描绘类、...
交互图则关注对象间的交互,包括序列图、协作图和用例图等。这些图表并不是孤立使用的,而是相互补充、协同工作,共同完成对系统的全面描述。 类图是UML结构图中最为常见的一种,它将系统中所有重要的类以及类之间...
UML 需求分析步骤实例解析 UML 需求分析步骤是软件开发过程中的一个重要环节,它可以帮助开发人员和用户对业务处理流程和目标软件系统的功能范围达成共同理解。本文将详细介绍 UML 需求分析步骤,并通过实例介绍来...
《网上考试系统 UML 用例图解析》 网上考试系统是一种基于信息技术的教育管理工具,旨在提升考试的效率和质量,实现考试的信息化管理。本文将深入探讨该系统的用例UML图,包括时序图在内的各种图表,以及系统的主要...
### 天气观察站UML设计实例解析 #### 引言 本文档介绍了一个通过UML(统一建模语言)来构建气象观察站系统的设计案例。该案例不仅展示了如何运用UML进行有效的软件架构设计,而且还涉及了多种设计模式的应用。通过...
1. **UML基础**:讲解UML的基本元素,如类图、对象图、用例图、序列图、协作图、状态图、活动图等,以及它们如何描绘系统的静态结构和动态行为。 2. **UML符号和语法**:详细介绍UML中的各种图的绘制规则,包括关系...
#### 用例图解析 用例图聚焦于系统功能和用户交互。其中,**客户**和**挂号员**是主要的参与者。客户可以执行**挂号操作**,这包括**直接挂号**和**确认预约**两种方式,体现了挂号流程的多样性和便利性。挂号员则...
下面将详细介绍UML用例图的基本元素和学习书籍的相关知识。 一、UML用例图 1. 用例(Use Case):用例是系统提供的服务或功能,描述了系统如何与外部参与者进行交互。它们通常以椭圆形状表示,描述了一个角色如何...
《UML建模实例解析——保险、图书馆与医院系统》 UML(统一建模语言)是软件工程领域中一种广泛使用的建模工具,它通过图形化的方式表达系统的结构、行为和关系,使得复杂的系统设计变得更为直观易懂。本资料集合...
#### 一、用例图解析 **用例图**在软件工程中扮演着至关重要的角色,尤其是在需求分析阶段。它描绘了外部用户(参与者)如何与系统交互,以及他们期望系统具备的功能。在本案例中,系统的目标用户主要包括上网用户...
本篇将围绕文档中的几个关键部分——用例图、活动图以及类图进行深入解析。 ### 一、用例图 #### 订单管理模块用例图 用例图用于描述系统的功能需求,展示的是用户与系统之间的交互。文档中提到了“订单管理模块...
1. **用例图**(1__单项练习之用例图.pdf):用例图描绘了系统外部用户(称为“actor”)与系统之间的交互,通过用例来表示用户的需求或系统功能。它强调了业务场景和系统功能的关系,是需求分析阶段的关键工具。 2...
它通过一系列图形符号来描述系统的结构和行为,包括类图、对象图、用例图、序列图、协作图、状态图、活动图等。 **二、UML的主要图类型** 1. **类图(Class Diagram)**:展示系统中的类、接口、继承关系、关联关系等...
《UML建模实例解析——管理系统篇》 UML(统一建模语言)是一种标准的图形建模语言,用于软件工程中的系统分析和设计。它提供了丰富的图表类型,包括用例图、类图、状态图、活动图、时序图和协作图,以帮助我们清晰...
1. **用例图(Use Case Diagram)**:描绘了系统与外部参与者之间的交互,展示了系统提供的功能和用户需求。 2. **类图(Class Diagram)**:描述了系统的静态结构,包括类、接口、继承关系、关联关系等。 3. **...
UML建模的用例图如图2所示。 类模型 在图书管理系统中,我们可以定义以下类: * 借书者(Reader):负责查询个人信息、查询图书信息、预定当前正在被别人借阅的图书、借阅图书和返还图书等。 * 图书管理员...
### UML标准建模语言及其应用实例解析 #### 引言 随着软件工程的发展,建模成为软件开发过程中不可或缺的一部分。UML(Unified Modeling Language,统一建模语言)作为一套标准化的图形化语言,被广泛应用于面向...
1. **用例分析**:用例图是UML中描述系统功能需求的主要工具,通过参与者(Actor)和用例(Use Case)之间的关系,展示了系统对外提供的服务。在实例中,你可以学习如何识别参与者,定义用例,并理解它们之间的关系...