UML中关联,组合与聚合等关系的辨析

简介:

以前学习面向对象的时候,常听到介绍对象之间的各种关系,常见的有关联,组合与聚合。

  关联:

  关联是一种最普遍和常见的关系形式。一般是指一个对象可以发消息给另外一个对象。典型的实现情况下指某个对象有一个指针或者引用指向一个实体变量,当通过方法的参数来传递或者创建本地变量来访问这种情况也可以称之为关联。

  典型的代码如下:

  1. class A  
  2. {  
  3.     private B itemB;  
  4. }

  也可能有如下的形式:

  1. class A  
  2. {  
  3.     void test(B b) {...}  
  4. }

  笼统的情况下,一般两个对象的引用,参数传递等形式产生的关系,我们都可以称之为关联关系。

  聚合(aggregation):

  聚合表示的是一种has-a的关系,同时,它也是一种整体-部分关系。它的特点在于,它这个部分的生命周期并不由整体来管理。也就是说,当整体这个对象已经不存在的时候,部分的对象还是可能继续存在的。它的uml图表示形式如下:

  我们用一个空心的箭头来表示聚合关系。

  笼统的说声明周期管理还是比较模糊。我们就以如图的Person和Address类来进一步的解释。假设我们要定义这两个对象,对于每个人来说,他有一个关联的地址。人和地址的关系是has-a的关系。但是,我们不能说这个地址是这个人的一个组成部分。同时,我们建立地址对象和人的对象是可以相对独立存在的。

  用代码来表示的话,典型的代码样式如下:

  1. public class Address  
  2. {  
  3. . . .  
  4. }  
  5. public class Person  
  6. {  
  7.      private Address address;  
  8.      public Person(Address address)  
  9.      {  
  10.          this.address = address;  
  11.      }  
  12.      . . .  
  13. }



我们通常通过如下的方式来使用Person对象:

  1. Address address = new Address();  
  2. Person person = new Person(address);

  或者:

Person person = new Person( new Address() );

  我们可以看到,我们是创建了一个独立的Address对象,然后将这个对象传入了Person的构造函数。当Person对象声明周期结束的时候,Address对象如果还有其他指向它的引用,是可能继续存在的。也就是说,他们的声明周期是相对独立的。

  组合(Composition):

  当理解了聚合的关系之后,再来看组合的关系就相对来说要好很多。和聚合比起来,组合是一种更加严格的has-a关系。它表示一种严格的组成关系。以汽车和引擎为例子,引擎是汽车的一个组成部分。他们是一种严格的部分组成关系,因此他们的声明周期也应该是一致的。也就是说引擎的声明周期是通过汽车对象来管理。

  组合的uml图表示如下:

  一般用一个实心的箭头表示组合。

  组合代码的典型示例如下:

  1. public class Engine  
  2. {  
  3. . . .   
  4. }  
  5.  
  6. public class Car  
  7. {  
  8.     Engine e = new Engine();  
  9.     .......  
  10. }

  Engine对象是在Car对象里面创建的,所以在Car对象生命周期结束的时候,Engine对象的生命周期也同样结束了。


本文出自seven的测试人生公众号最新内容请见作者的GitHub页:http://qaseven.github.io/

目录
相关文章
|
数据可视化 uml
UML类图的六大关系,最佳学习理解方式
UML类图的六大关系,最佳学习理解方式
348 0
UML类图的六大关系,最佳学习理解方式
|
数据可视化 uml
UML图讲解(关联关系,单向关联,双向关联,自关联,组合关系,依赖关系,继承关系,实现关系)
UML图讲解,关联关系,单向关联,双向关联,自关联,组合关系,依赖关系,继承关系,实现关系。
1946 0
UML图讲解(关联关系,单向关联,双向关联,自关联,组合关系,依赖关系,继承关系,实现关系)
|
11月前
|
uml C++ 容器
「软件设计」UML中关联,聚合和组合的区别是什么?
「软件设计」UML中关联,聚合和组合的区别是什么?
|
11月前
|
uml C++ 容器
「软件设计」UML中关联,聚合和组合区别
「软件设计」UML中关联,聚合和组合区别
|
测试技术 uml
用例关系 和 UML类关系
用例关系 和 UML类关系
88 0
用例关系 和 UML类关系
|
测试技术 uml
UML图的依赖、关联、聚合、组合关系(突击软考)
UML图的依赖、关联、聚合、组合关系(突击软考)
183 0
|
测试技术 uml
一次讲清:UML类图中的六大关系
今天给大家分享UML图以及其中最重要的UML类图的几大关系,几分钟交会大家如何制作出UML类图。在UML的静态机制中类图是一个重点,它不但是设计人员关心的核心,更是实现人员关注的核心。
一次讲清:UML类图中的六大关系
|
uml
通过简单例子 | 快速理清 UML 中类与类的六大关系
通过简单例子 | 快速理清 UML 中类与类的六大关系
79 0
通过简单例子 | 快速理清 UML 中类与类的六大关系
|
uml
UML - UML中类与类的关系
UML - UML中类与类的关系
149 0
UML - UML中类与类的关系
|
数据可视化 测试技术 uml
UML——概述(事物、关系、图)
UML——概述(事物、关系、图)
175 0
UML——概述(事物、关系、图)