UML面向对象分析与建模-【5】交互图

 

一、概述

交互图是用来表达系统的各个对象之间如何交互,如何合作完成某个行为的动态模型工具,它与用例图、状态图、活动图等共同构成了系统的行为视图。

交互图主要用于对用例图中的控制流进行建模,它包括序列图和协作图,其中,序列图按时间次序描述系统中各对象如何通过消息交互,协作图从空间上描述收发消息的对象的结构关系。

二、序列图

序列图是一种交互图,描述了系统中各个对象之间传递消息的时间次序,用来表示用例的行为顺序,从而为对象类图中概括对象的行为、划分对象类的职责提供依据。它依赖与用例图,如果说用例图是对用户需求的第一次抽象,那通过序列图,用户的需求就会变得更加具体,系统中各个对象的行为和角色也更加清晰。

序列图也称为时序图,包括对象、生命线、消息和激活。其中激活表示该对象被占用以完成某个任务,撤销表示对象处于空闲等待消息状态。在UML中,矩形表示对象是激活的,称为激活期或控制期。对象完成任务后被撤销,一般发生在一个消息离开对象生命线的时候。

同步消息代表一个通过操作调用的嵌套的控制流,该操作调用要求操作同步。同步消息的接收方必须是一个被动对象,即它是一个需要通过消息的驱动才能执行动作的对象。异步消息代表一个非同步的信号请求,该信号异步要求一个操作。异步消息的发送方和接收方是并行工作的。异步消息的接收方必须是一个主动对象,它不需要消息驱动就可以执行对象的动作。

一个对象可以在交互中动态创建。动态创建的对象生命线起始位置低于正常的对象。一个对象可以在交互中销毁。当一个对象已经完成了自己的全部动作或活动后,可以在对象生命线的末端使用删除标志来销毁,对象可以自己销毁自己(析构函数)。

自调用指一个对象调用自己。当指定的事件已经出现或者操作已完成时,接收方立即发送一个异步消息给发送方,通知发送方可以继续进行后续的动作,这就是回调机制。回调发送的是一个异步消息,收发双方并行进行各自的活动,并且并非任何异步消息都要有相对应的回调消息,而返回消息则是与同步消息匹配的,同步消息的发送方必须等待接收方响应后才能继续后续的动作。

三、协作图

协作图强调以消息传递为纽带的一组对象之间的组织结构,用于描述系统的行为如何由系统的各对象合作完成的。

序列图和协作图都可以用来表示系统的动态行为,前者侧重强调消息的时间顺序,即对象间的通信模式;后者侧重强调对象间的静态连接关系,即对象间的协作。

协作图没有时间维,所以消息和并发线程的时间顺序必须用序号表示。协作图描述了两个方面:对交互作用的对象的静态结构描述,包括相关的对象的关系、属性和操作;为完成工作在对象间交换的消息的时间顺序的描述。第一个方面称为协作所提供的“上下文”,第二个方面称为协作关系的“交互作用”。

四、交互图建模

序列图建模基本步骤:

(1)       确定交互的上下文。

(2)       找出参与交互的对象类的角色,并横向排列在序列图的顶部。最重要的或启动交互的对象放在最左边,依次向右排列,动态创建的对象应放在被创建的时间点位置。

(3)       对每个对象设置一条垂直向下的生命线。

(4)       从初始化交互的消息开始,自顶向下在生命线上放置消息,注意各类不同消息的表示法。

(5)       在生命线上绘制对象的激活期,包括动态对象的创建和销毁。

(6)       根据消息之间的关系,确定循环结构及其循环参数和出口条件。

协作图建模的基本步骤:

(1)       确定交互的上下文。

(2)       找出参与交互的对象类的角色,把它们作为图形的节点安置在协作图中。最重要的对象放在中央。

(3)       设置对象的初始性质。

(4)       给出对象间的关联,注意必要的修饰,如构造型<<global>><<local>>等。

(5)       从初始化交互的消息开始,按交互顺序放置其它消息,注意消息的序号不可缺少。

(6)       处理特殊的情况,如循环、主动对象、异步消息、多对象等。

序列图和协作图都是交互图,但它们间并不完全相同,表现为:

(1)       序列图和协作图都能等价地表现系统运行中对象的交互行为。

(2)       序列图表达了时间的消息序列,体现了系统行为的顺序。

(3)       协作图表达了系统中对象间的关联和消息的相互作用,体现了系统的静态结构。

(4)       序列图适合按时间次序建立系统的控制流模型,协作图适合按对象组织建立系统的控制流模型。

 

 

    参考文献:

    [1] 唐学忠等著. UML面向对象分析与建模. 电子工业出版社. 2008

    [2] 蔡敏等著. UML基础与ROSE建模教程. 人民邮电出版社. 2006

    [3] Carlo Ghezzi等著. 施平安译. 软件工程基础(第2版) 清华大学出版社. 2003

    [4] 参考网站:

       http://www.omg.org/UML

       http://www.rational.com/UML

       http://www.software.ibm.com/ad/ocl

时间: 2024-09-20 05:28:16

UML面向对象分析与建模-【5】交互图的相关文章

UML面向对象分析与建模-【2】UML语言基础

  一.UML的主要内容 UML主要文件包括UML概要.UML语义.UML表示法指南和对象约束语言规约. 二.UML的主要特点 UML主要特点包括统一标准.面向对象.可视化及表示能力强大.独立于过程和容易使用掌握.UML不是一个独立的软件工程方法,而是面向对象软件工程方法中的一个部分.UML贯穿软件系统开发的需求分析.系统分析.系统设计.系统实现和测试五个阶段. 三.UML建模中9种图的特点 1.       用例图 用例图描述系统外部的活动者(角色)与系统提供的用例之间的某种联系.它着重从系统

UML面向对象分析与建模-【3】用例图

  一.用例图的描述 用例(Use Case)是指系统的外部事物(活动者.设备或外部系统)与系统交互,它表达了系统的功能,即系统所提供的服务. 用例图是一种描述用例的可视化工具,用简单的图形元素表示出系统的活动者.用例及它们之间的关系,准确地表达了活动者与系统的交互情况和系统所能提供的服务.用例图是从用户角度而不是从开发者角度来描述对软件产品的需求,分析产品所需的功能和动态行为. 二.活动者 确定活动者.活动者可以通过泛化关系定义. 1.       系统的主要客户是谁 2.       谁从该

UML面向对象分析与建模-【6】状态图

  一.概述 在一般的面向对象技术中,状态图又称为状态迁移图.描述了一个特定对象的所有可能状态以及由于各种事件的发生而引起的状态之间的迁移.大多数面向对象技术都使用状态图来描述一个对象在其生命周期中的行为. 二.状态 在所有动态图(序列图.协作图.状态图.活动图)中,消息是作为对象间的一种通信方式来表示的.消息包括简单消息.同步消息和异步消息.可以将一个简单消息和同步消息合并成一个消息. 在UML中,对于状态的定义着重于对象行为的规则,状态描述了一个对象生命周期中的一个时间段.它可以用三种附加方

UML面向对象分析与建模-【1】面向对象技术概述

    一.软件开发方法 常见的软件开发方法有面向过程的开发方法,面向数据结构的开发方法和面向对象的开发方法.其中面向过程的开发方法也称为面向功能的软件开发方法或面向数据流的软件开发方法.结构化方法强调过程抽象和功能模块化.它一般利用图形表达用户需求,使用的手段有数据流图.数据字典.结构化语言.判定表及判定树等.面向数据结构的开发方法适合于求解算法依赖于问题描述的数据结构之类的情况.这种方法最适合在完成了软件结构设计之后,用它来设计每个模块的处理过程.它根据问题的数据结构定义一组映射,把问题的数

UML面向对象分析与建模-【4】类图和对象图

  一.概述 UML的类图和对象图表达的是对象模型的静态结构方面. 类图描述的是一种静态关系,在系统的整个生命周期都是有效的.通过分析问题域和用例,就可以得到相关的类,然后再把逻辑上相关的类封装成包.这样就可以很好地体现系统的分层结构,使人们对系统层次关系一目了然. 对象图是类图的实例,它的表示方式与类图基本相似.它们的不同之处在于对象图显示类图的多个对象实例,而不是实际的类.一个对象图是类图的一个实例,对象图只能在系统的某一时间存在. 二.对象类 对象类简称类,是一种重要的分类器,用来描述结构

《面向对象分析与设计》一1.6关于统一建模语言UML

1.6关于统一建模语言UML UML最初是在多种面向对象分析与设计方法相互融合的基础上形成的,后来发展成为也可以用于业务建模以及其他非软件系统建模的语言.它于1997年11月被对象管理组织(Object Management Group)采纳为建模语言规范,随后被产业界和学术界广泛接受. UML定义了建立系统模型所需要的概念并给出了表示法,但它并不涉及如何进行系统建模.因此它只是一种建模语言,而不是一种建模方法.UML是独立于开发过程的,也就是说它可以适用于不同的开发过程. UML 2.4规范由

面向对象分析与设计—四色原型模式(彩色建模、领域无关模型)

面向对象分析与设计-四色原型模式(彩色建模.领域无关模型) 1.背景介绍 至今我都清楚的记得我第一次被面试官问起什么叫"建模"技术时的情景,那是好 几年前的事情了,当时是胸有成竹的去面试一个有关系统分析.设计的.NET高级软件工程师岗位.面试官几乎没问我有关.NET方面的任何技术实现,他就简 单的问了问:"你如何把握你所分析出来的系统的正确性?",我当时有点小激动,觉得这个问题应该很简单嘛,都是概念而已,让他直接点问,结果他来一句: "你懂建模吗?,能给我

.NET应用架构设计—面向对象分析与设计四色原型模式(彩色建模、领域无关模型)(概念版)

阅读目录: 1.背景介绍 2.问自己,UML对你来说有意义吗?它帮助过你对系统进行分析.建模吗? 3.一直以来其实我们被一个缝隙隔开了,使我们对OOAD遥不可及 4.四色原型模式填补这个历史缝隙,让我们真的看见OOAD的希望 5.在四色原型上运用彩色建模增强视觉冲击力 6.通过四色原型模式建模出领域无关模型 7.结束语:建模时你可以不考虑具体实现,但是建模者要懂技术实现 1.背景介绍 至今我都清楚的记得我第一次被面试官问起什么叫"建模"技术时的情景,那是好几年前的事情了,当时是胸有成竹

《UML面向对象设计基础》目录—导读

版权声明 UML面向对象设计基础 Authorized translation from the English language edition, entitled Fundamentals of Object-Oriented Design in UML, 1E, 9780201699463 by Meilir Page-Jones, published by Pearson Education, Inc, publishing as Addison-Wesley Professional,