用例图主要用来描述“用户、需求、系统功能单元”之间的关系。它展示了一个外部用户能够观察到的系统功能模型图。

  【用途】:帮助开发团队以一种可视化的方式理解系统的功能需求。

  用例图所包含的元素如下:

  1. 参与者(Actor)

  表示与您的应用程序或系统进行交互的用户、组织或外部系统。用一个小人表示。

UML用例图总结_父类

  2. 用例(Use Case)

   用例就是外部可见的系统功能,对系统提供的服务进行描述。用椭圆表示。

UML用例图总结_用例图_02

  3. 子系统(Subsystem)

  用来展示系统的一部分功能,这部分功能联系紧密。

UML用例图总结_用例_03

  4. 关系

  用例图中涉及的关系有:关联、泛化、包含、扩展。

  如下表所示:

UML用例图总结_用例图_04

  a. 关联(Association)

  表示参与者与用例之间的通信,任何一方都可发送或接受消息。

  【箭头指向】:指向消息接收方

UML用例图总结_用例_05

  b. 泛化(Inheritance)

  就是通常理解的继承关系,子用例和父用例相似,但表现出更特别的行为;子用例将继承父用例的所有结构、行为和关系。子用例可以使用父用例的一段行为,也可以重载它。父用例通常是抽象的。

  【箭头指向】:指向父用例

UML用例图总结_子类_06

  c. 包含(Include)

  包含关系用来把一个较复杂用例所表示的功能分解成较小的步骤。

  【箭头指向】:指向分解出来的功能用例

UML用例图总结_父类_07

  d. 扩展(Extend)

  扩展关系是指用例功能的延伸,相当于为基础用例提供一个附加功能。

  【箭头指向】:指向基础用例

UML用例图总结_父类_08

  e. 依赖(Dependency)

  以上4种关系,是UML定义的标准关系。但VS2010的用例模型图中,添加了依赖关系,用带箭头的虚线表示,表示源用例依赖于目标用例。

  【箭头指向】:指向被依赖项

UML用例图总结_子类_09

  5. 项目(Artifact)

  用例图虽然是用来帮助人们形象地理解功能需求,但却没多少人能够通看懂它。很多时候跟用户交流甚至用Excel都比用例图强,VS2010中引入了“项目”这样一个元素,以便让开发人员能够在用例图中链接一个普通文档。

  用依赖关系把某个用例依赖到项目上:

UML用例图总结_泛化_10

  然后把项目-》属性 的Hyperlink设置到你的文档上;

  这样当你在用例图上双击项目时,就会打开相关联的文档。

  6. 注释(Comment)

UML用例图总结_泛化_11 

  包含(include)、扩展(extend)、泛化(Inheritance) 的区别:

包含关系下,去掉子用例,父用例将不能使用;扩展关系则不会,扩展关系中子用例是对父用例的增强型描述


1、包含<<include>>

包含是指当多个用例中存在相同的事件流时,可以把这些公共事件流抽象成公共用例,这个公共用例称之为抽象用例(跟类的概念有点相像, 类是多个对象的抽象定义),而原始用例称为基础用例,基础用例与抽象用例之间就是包含关系。但是值得注意的是,对于包含关系而言,基础用例是抽象用例执行 中不可缺少的一部分,基础用例一般不单独存在且基础用例不知道抽象用例的存在而抽象用例知道基础用例的存在。包含关系是箭头从抽象用例指向基础用例(也就 是从父类指向子类)。

2、扩展<<extend>>

如果一个用例明显地混合了两种或两种以上不同的场景,可以将这个用例分为一个基础用例和一个扩展用例。扩展关系 用<<extend>>关系表示,箭头指向基本用例(也就是从子类指向父类)。与此同时,扩展用例是基础用例在某些特定条件下触 发产生的,扩展用例不是基础用例必须存在的部分,扩展用例可以单独存在,扩展用例知道基础用例的存在而基础用例不知道基础用例的存在。

3、泛化<<>generalization>>

泛化关系是一种继承关系,子用例将继承基用例的所有行为,也就是任何使用基用例的地方都可以使用子用例来代替。我平时是这样记住这个 关系的,就是子类从父类中继承,父类就是子类的泛化。因为泛化和继承本就是一对反关系。泛化关系在用例图中用空心箭头表示,箭头方向从子用例指向基用例。

    UML用例图中的三种关系,include,extend和generalization,尤其是包含和扩展,一定要分清它们二者的区别,这对我们掌握这部分的内容是很有帮助的。

  条件性:泛化中的子用例和include中的被包含的用例会无条件发生,而extend中的延伸用例的发生是有条件的;

  直接性:泛化中的子用例和extend中的延伸用例为参与者提供直接服务,而include中被包含的用例为参与者提供间接服务。

  对extend而言,延伸用例并不包含基础用例的内容,基础用例也不包含延伸用例的内容。

  对Inheritance而言,子用例包含基础用例的所有内容及其和其他用例或参与者之间的关系;

 

  一个用例图示例:

UML用例图总结_子类_12 

  牢骚:

  感觉用例图还不成熟,并不能很好地表达系统的需求, 没有UML背景的用户几乎不知道画的是些什么。

  其次,包含关系、扩展关系的箭头符号竟然是同样的箭头,仅靠上方写个文字来加以区别,翻译成其他语言的话,几乎就不知道代表什么意思。扩展关系的箭头朝向也很难理解,为何要指向基用例,而不指向扩展用例。

  VS2010添加的“项目”元素,是个很好的创新,能够在用例图中关联word, excel这些文档。但为什么不把这些功能直接集成到用例里面,双击用例就弹出一份文档岂不更容易理解,非要画蛇添足地加一个元件,仅仅为了提供个链接功能。 

  用例描述表:

  鉴于用列图并不能清楚地表达功能需求,开发中大家通常用描述表来补充某些不易表达的用例,下图的表给大家提供一个参考:

UML用例图总结_父类_13