随笔-9  评论-168  文章-266  trackbacks-0

uml中描述对象和类之间相互关系的方式包括:依赖(dependency),关联(association),聚合(aggregation),组合(composition),泛化(generalization),实现(realization)等。

依赖 (dependency):元素a的变化会影响元素b,但反之不成立,那么b和a的关系是依赖关系,b依赖a;类属关系和实现关系在语义上讲也是依赖关 系,但由于其有更特殊的用途,所以被单独描述。uml中用带箭头的虚线表示dependency关系,箭头指向被依赖元素。

泛化(generalization):通常所说的继承(特殊个体 is kind of 一般个体)关系,不必多解释了。uml中用带空心箭头的实线线表示generalization关系,箭头指向一般个体。

实现(realize):元素a定义一个约定,元素b实现这个约定,则b和a的关系是realize,b realize a。这个关系最常用于接口。uml中用空心空心箭头和虚线表示realize关系,箭头指向定义约定的元素。

关联(association):元素间的结构化关系,是一种弱关系,被关联的元素间通常可以被独立的考虑。uml中用实线表示association关系,箭头指向被依赖元素。

聚合(aggregation):关联关系的一种特例,表示部分和整体(整体 has a 部分)的关系。uml中用带空心菱形头的实线表示aggregation关系,菱形头指向整体。

组 合(composition):组合是聚合关系的变种,表示元素间更强的组合关系。如果是组合关系,如果整体被破坏则个体一定会被破坏,而聚合的个体则可 能是被多个整体所共享的,不一定会随着某个整体的破坏而被破坏。uml中用带实心菱形头的实线表示composition关系,菱形头指向整体。

其中依赖(dependency)的关系最弱,而关联(association),聚合(aggregation),组合(composition)表示的关系依次增强。换言之关联,聚合,组合都是依赖关系的一种,聚合是表明对象之间的整体与部分关系的关联,而组合是表明整体与部分之间有相同生命周期关系的聚合。

而关联与依赖的关系用一句话概括下来就是,依赖描述了对象之间的调用关系,而关联描述了对象之间的结构关系。

后面的例子将针对某个具体目的来独立地展示各种关系。虽然语法无误,但这些例子可进一步精炼,在它们的有效范围内包括更多的语义。

依赖(dependency)

实体之间一个“使用”关系暗示一个实体的规范发生变化后,可能影响依赖于它的其他实例(图d)。 更具体地说,它可转换为对不在实例作用域内的一个类或对象的任何类型的引用。其中包括一个局部变量,对通过方法调用而获得的一个对象的引用(如下例所 示),或者对一个类的静态方法的引用(同时不存在那个类的一个实例)。也可利用“依赖”来表示包和包之间的关系。由于包中含有类,所以你可根据那些包中的 各个类之间的关系,表示出包和包的关系。

图d


关联(association)

实体之间的一个结构化关系表明对象是相互连接的。箭头是可选的,它用于指定导航能力。如果没有箭头,暗示是一种双向的导航能力。在java中,关联(图e) 转换为一个实例作用域的变量,就像图e的“java”区域所展示的代码那样。可为一个关联附加其他修饰符。多重性(multiplicity)修饰符暗示 着实例之间的关系。在示范代码中,employee可以有0个或更多的timecard对象。但是,每个timecard只从属于单独一个 employee。

图e

聚合(aggregation)

聚合(图f)是关联的一种形式,代表两个类之间的整体/局部关系。聚合暗示着整体在概念上处于比局部更高的一个级别,而关联暗示两个类在概念上位于相同的级别。聚合也转换成java中的一个实例作用域变量。

关联和聚合的区别纯粹是概念上的,而且严格反映在语义上。聚合还暗示着实例图中不存在回路。换言之,只能是一种单向关系。

图f



合成(composition)

合成 (图g) 是聚合的一种特殊形式,暗示“局部”在“整体”内部的生存期职责。合成也是非共享的。所以,虽然局部不一定要随整体的销毁而被销毁,但整体要么负责保持局 部的存活状态,要么负责将其销毁。局部不可与其他整体共享。但是,整体可将所有权转交给另一个对象,后者随即将承担生存期职责。

employee和timecard的关系或许更适合表示成“合成”,而不是表示成“关联”。

图g

泛化(generalization)

泛化(图h)表示一个更泛化的元素和一个更具体的元素之间的关系。泛化是用于对继承进行建模的uml元素。在java中,用extends关键字来直接表示这种关系。

图h


实现(realization)

实例(图i)关系指定两个实体之间的一个合同。换言之,一个实体定义一个合同,而另一个实体保证履行该合同。对java应用程序进行建模时,实现关系可直接用implements关键字来表示。

图i




转自: 

网站地图