一.UML简介
UML(统一建模语言,Unified Modeling Language)是一种定义良好、易于表达、功能强大且普遍适用的可视化建模语言。它融入了软件工程领域的新思想、新方法和新技术。它的作用域不限于支持面向对象的分析与设计,还支持从需求分析开始的软件开发的全过程。在系统分析阶段,我们一般用UML来画很多图,主要包括用例图、状态图、类图、活动图、序列图、协作图、构建图、配置图等等,要画哪些图要根据具体情况而定。其实简单的理解,也是个人的理解,UML的作用就是用很多图从静态和动态方面来全面描述我们将要开发的系统。
二.用例建模简介
用例建模是UML建模的一部分,它也是UML里最基础的部分。用例建模的最主要功能就是用来表达系统的功能性需求或行为。依我的理解用例建模可分为用例图和用例描述。用例图由参与者(Actor)、用例(Use Case)、系统边界、箭头组成,用画图的方法来完成。用例描述用来详细描述用例图中每个用例,用文本文档来完成。
1. 用例图
参与者不是特指人,是指系统以外的,在使用系统或与系统交互中所扮演的角色。因此参与者可以是人,可以是事物,也可以是时间或其他系统等等。还有一点要注意的是,参与者不是指人或事物本身,而是表示人或事物当时所扮演的角色。比如小明是图书馆的管理员,他参与图书馆管理系统的交互,这时他既可以作为管理员这个角色参与管理,也可以作为借书者向图书馆借书,在这里小明扮演了两个角色,是两个不同的参与者。参与者在画图中用简笔人物画来表示,人物下面附上参与者的名称。
用例是对包括变量在内的一组动作序列的描述,系统执行这些动作,并产生传递特定参与者的价值的可观察结果。这是 UML对用例的正式定义,对我们初学者可能有点难懂。我们可以这样去理解,用例是参与者想要系统做的事情。对于对用例的命名,我们可以给用例取一个简单、描述性的名称,一般为带有动作性的词。用例在画图中用椭圆来表示,椭圆下面附上用例的名称。
系统边界是用来表示正在建模系统的边界。边界内表示系统的组成部分,边界外表示系统外部。系统边界在画图中方框来表示,同时附上系统的名称,参与者画在边界的外面,用例画在边界里面。因为系统边界的作用有时候不是很明显,所以我个人理解,在画图时可省略。
箭头用来表示参与者和系统通过相互发送信号或消息进行交互的关联关系。箭头尾部用来表示启动交互的一方,箭头头部用来表示被启动的一方,其中用例总是要由参与者来启动。
2. 用例描述
用例图只是简单地用图描述了一下系统,但对于每个用例,我们还需要有详细的说明,这样就可以让别人对这个系统有一个更加详细的了解,这时我们就需要写用例描述。
对于用例描述的内容,一般没有硬性规定的格式,但一些必须或者重要的内容还是必须要写进用例描述里面的。用例描述一般包括:简要描述(说明)、前置(前提)条件、基本事件流、其他事件流、异常事件流、后置(事后)条件等等。下面说说各个部分的意思:
简要描述:对用例的角色、目的的简要描述;
前置条件:执行用例之前系统必须要处于的状态,或者要满足的条件;
基本事件流:描述该用例的基本流程,指每个流程都“正常”运作时所发生的事情,没有任何备选流和异常流,而只有最有可能发生的事件流;
其他事件流:表示这个行为或流程是可选的或备选的,并不是总要总要执行它们;
异常事件流:表示发生了某些非正常的事情所要执行的流程;
后置条件:用例一旦执行后系统所处的状态;
三. 用例图和用例描述设计实例
这里用我开发的一个家教网站来简单的分析用例图的画法和用例描述的写法。这个网站我用UML完整的分析一下,以下我提取了用例图和用例描述的部分。这个家教网站分为前台客户系统和后台管理系统。
前台客户系统的用例图如下:
后台管理系统用例图如下:
对于用例描述,篇幅有限,我在这里只列了后台管理系统中的网站公告发布这个用例的描述。如下:
用例名称:网站公告发布 |
用例标识号:202 |
参与者:负责人 |
简要说明:
负责人用来填写和修改家教网站首页的公告,公告最终显示在家教网站的首页上。 |
前置条件:
负责人已经登陆家教网站管理系统 |
基本事件流:
1.负责人鼠标点击“修改公告”按钮
2.系统出现一个文本框,显示着原来的公告内容
3.负责人可以在文本框上修改公告,也可以完全删除,重新写新的公告
4.负责人编辑完文本框,按“提交”按钮,首页公告就被修改
5.用例终止 |
其他事件流A1:
在按“提交”按钮之前,负责人随时可以按“返回”按钮,文本框的任何修改内容都不会影响网站首页的公告 |
异常事件流:
1.提示错误信息,负责人确认
2.返回到管理系统主页面 |
后置条件:
网站首页的公告信息被修改 |
注释:无 |
四. 总结其实用例建模并不是这么简单,它涉及到的知识还有很多,这里只是简单的介绍一下。
感谢:http://www.51cto.com 2006-01-13 10:10 出处:51CTO.com整理
补充:
用例之间也可以存在包含、扩展和泛化等关系:
(1)包含关系:用例可以简单地包含其他用例具有的行为,并把它所包含的用例行为做为自身行为的一部分,这被称作包含关系。
(2)扩展关系:扩展关系是从扩展用例到基本用例的关系,它说明为扩展用例定义的行为如何插入到为基本用例定义的行为中。它是以隐含形式插入的,也就是说,扩展用例并不在基本用例中显示。在以下几种情况下,可使用扩展用例:
a.表明用例的某一部分是可选的系统行为(这样,您就可以将模型中的可选行为和必选行为分开);
b.表明只在特定条件(如例外条件)下才执行的分支流;
c.表明可能有一组行为段,其中的一个或多个段可以在基本用例中的扩展点处插入。所插入的行为段和插入的顺序取决于在执行基本用例时与主角进行的交互。
图2.3给出了一个扩展关系的例子,在还书的过程中,只有在例外条件(读者遗失书籍)的情况下,才会执行赔偿遗失书籍的分支流。
(3)泛化关系:用例可以被特别列举为一个或多个子用例,这被称做用例泛化。当父用例能够被使用时,任何子用例也可以被使用。如在图2.4中,订票是电话订票和网上订票的抽象。
------------------------------------------------------------
泛化、包含和扩展
泛化(Generalization)在面向对象的技术中无处不在,它的另一个名字也许更为著名,就是“继承”。下图给出了一个使用泛化的用例图:
可知,在用例图中,角色和用例都能够泛化。角色的泛化/继承很容易理解,因为角色本来就是类(Class),它是一种版型(stereotype)为Actor的类,所以角色的继承直观而自然。但是用例的继承实际上分为两种情况,并不是简单的使用泛化,而是使用扩展(extended)和包含(include)两种泛化的特例。
扩展用于子用例的动作步骤基本上和父用例的动作步骤相同,只是增加了另外的一些步骤的情况下。包含用于子用例包含了所有父用例的动作,它将父用例作为了自己的一个大步骤,子用例常常包含一个以上的父用例。如下图:
分享到:
相关推荐
学习UML用例图,不仅能够帮助我们梳理需求,还能促进团队间的沟通,使得非技术人员也能理解复杂的系统设计。通过创建和分析用例图,我们可以发现潜在的问题,优化系统设计,确保最终产品的功能符合用户需求。 在...
1. **用例图(Use Case Diagram)**: 描述了系统外部参与者(actors)与系统提供的服务(use cases)之间的关系,展示了系统的功能需求。 2. **类图(Class Diagram)**: 展示了类、接口及其之间的关系,如继承、...
- UML提供了多种图表类型,包括用例图、类图、序列图、状态图、活动图、组件图、部署图等,覆盖了软件开发的各个阶段。 2. **用例图(Use Case Diagram)** - 用例图展示了系统与外部参与者之间的交互,用于描绘...
2. **图示**:UML包括多种图表,如用例图、类图、序列图、状态图、活动图、组件图、部署图等,每种图都有其特定的用途,用于表示不同层面的系统结构和行为。 3. **元素**:UML元素是构建模型的基本单元,包括类、...
**UML技术学习(附物流系统用例图)** UML,全称为统一建模语言(Unified Modeling Language),是软件工程领域中一种重要的可视化建模工具。它为系统设计者提供了一种标准化的方式来描述软件系统的需求、结构和...
Visio提供了多种UML图的模板,包括用例图、类图、序列图、状态图等,帮助用户直观地描绘系统行为和结构。 三、Visio2003与UML2.2 Visio2003版本虽然相对较旧,但依然支持UML1.4,通过扩展可以支持部分UML2.2特性。...
本篇文章将深入探讨如何运用UML的用例图、协作图和序列图来构建一个简单的选课系统,旨在为初学者提供实用的参考。 一、用例图(Use Case Diagram) 用例图是UML中的重要组成部分,它展示了系统的主要参与者...
2. **全功能建模**:ArgoUML支持UML的多种图表类型,如类图、用例图、序列图、状态机图等,可以满足用户对软件设计的不同需求。 3. **用户友好界面**:其简洁直观的界面使得用户能够轻松上手,无需深厚的编程背景也...
**UML用例图实例讲解** UML(统一建模语言)是软件开发过程中的一种标准化建模工具,它提供了一套图形化的方式来描述系统的行为、结构和关系。在UML中,用例图(Use Case Diagram)是描述系统外部参与者(Actor)与...
**UML用例图详解** 在软件工程领域,UML(统一建模语言)是一种标准的建模工具,用于描述系统的行为和结构。其中,用例图(Use Case Diagram)是UML的一种静态视图,它捕捉了系统与外部参与者之间的交互。本文将...
这一阶段通常使用UML类图、用例图、序列图等工具进行可视化描述。 5. **软件工程第5讲--软件实现**:实现阶段是将设计转化为代码的过程,程序员依据详细设计文档编写程序,并遵循编码规范,确保代码的可读性和可...
2. **用例图(Use Case Diagram)**:用例图描绘了系统与外部参与者之间的交互,以及用例(系统功能)之间的关系。它专注于需求分析,展示用户的需求和系统的功能边界。 3. **序列图(Sequence Diagram)**:序列图描述...
UML 2.5包括了类图、对象图、用例图、序列图、协作图、状态图、活动图、组件图、部署图等九种基本图表类型,每种图表都有其特定的用途,帮助开发者从不同角度理解和描述系统。 Visio 2013为UML建模提供了丰富的支持...
它提供了基本的UML图表绘制功能,包括类图、用例图、序列图等,能够满足日常开发中的大部分需求。作为一个绿色版工具,JUDE-Community无需安装,解压即用,方便快捷,不占用系统资源,对电脑配置要求较低,适合在...
ArgoUML支持UML 1.4标准,这意味着它可以绘制包括类图、对象图、用例图、序列图、协作图、状态图、活动图和组件图在内的所有基本UML图表。这些图表对于理解和沟通软件设计至关重要,可以帮助开发团队在项目早期就...
该UML图包括HR系统的用例图,类图,时序图。而且类图是基于简单工厂模式所画,对很多初学UML的人来说很有帮助。
- **用例图(Use Case Diagram)**:展示了系统参与者与系统提供的功能之间的关系。 - **类图(Class Diagram)**:描绘了类、接口及其相互关系。 - **序列图(Sequence Diagram)**:展示对象间交互的时间顺序。...
- **需求分析**:通过用例图、活动图等模型描述系统的行为和交互。 - **系统设计**:利用类图、组件图、部署图等描述系统的结构和配置。 - **代码实现**:通过序列图、状态机图等指导程序的编写和调试。 - **系统...
本文将详细探讨如何运用UML进行贪吃蛇游戏的课程设计,并重点介绍其中的类图、活动图、顺序图和用例图。 首先,UML类图是描绘系统中类的静态结构和关系的工具。在贪吃蛇游戏中,我们可以定义以下几个主要的类:`...