您的位置:首页 > 编程语言 > Java开发

UML中类之间的关系及其Java代码例子

2008-03-10 16:19 351 查看
关系是事物之间的联系。类之间有4种重要的关系:依赖、泛化、关联和实现。这些关系都可以映射到代码里。


赖是一种使用关系,描述了一个事物的规格说明的变化可能会影响到使用它的另一个事物(反之不一定)。在UML中表示为一条指向被依赖事物的虚线。依赖有很
多构造型,不过一般不需要使用,以免搞得过份复杂。其实另外3种关系泛化、关联和实现都可以算作是某种依赖关系,只不过它们有比较强的语义和重要的作用,
所以划分出来。一般对类关系建模的时候,先对泛化、关联和实现建模,剩下的关系都可以看作依赖了。

对应到代码中,依赖关系可能有很多种形式,例如

public class A

{

public B getB(C c, D d)

{

E e = new E();

B b = new B(c, d, e);

}

}

这里类A就依赖于类B(方法返回类)、C和D(参数类)、E(方法内变量的类),因为这几个类的变化都有可能影响到类A

泛化是一般事物(称为超类或父类)和较特殊的事务(称为子类)之间的关系,对类来说一般就是继承了,如:public Class A extends B。一般用一个带空心箭头的实线表示泛化关系。

关联是一种结构关系,说明一个事物的对象与另一个事物的对象相联系。给定一个连接两各类的关联,可以从一个类的对象导航到另一个类的对象。

一般把关联画为连接相同或者不同的类一条实线。关联可以有方向,即导航。一般不作说明的时候,导航是双向的,不需要在线上标出箭头。大部分情况下导航是单向的,可以加一个箭头表示。

关联在代码中一般表示为属性,例如

public class A

{

private B b;

}

可以认为有一个A指向B的关联。

如果B也关联到A,那么它们就是双向的关联。

有的时候B不是A的属性,但是也可以有关联关系,例如:

public class A

{

public B[] getBs()

{...}

}

方法getBs可能去查数据库,找到A和B之间的关联关系。


个类之间的简单关联表示了两个同等地位类之间的结构关系。聚合也是一种关联关系,与简单关联不同的是,它描述的是一个整体和组成部分的关系,即“has-
a”关系,意思是整体对象拥有部分对象,例如学校和学生的关系。聚合的整体和部分之间在生命周期上没有什么必然的联系,部分对象可以在整体对象创建之前创
建,也可以在整体对象销毁之后销毁。聚合用带一个空心菱形(整体的一端)的实线表示。

public Class Person

{...}
public Class School

{

private ArrayList students;

private void addStudent(Person person)

{

students.add(person);

}

}

组合则是比聚合更强的关联形式。组合是指带有很强的拥有有关系且整体与部分的生命周期一致的聚合关联形式。例如Windows的窗口和窗口上的菜单就是组
合关系。生命周期一致指的是部分必须在组合创建的同时或者之后创建,在组合销毁之前或者同时销毁,部分的生命周期不会超

出组合的生命周期。组合是用带实心菱形的实线来表示。

public Class Menu

{...}

public Class Window

{

private Menu menu;

}

组合和聚合在代码实现上的主要差别在于生命周期的实现上,组成需要负责其部分的创建和销毁。

public Class School

{

public School()

{...}//不需要创建任何Person对象,其Students都是已有的Person对象

public void destroy()

{...}//只需要关掉School对象和断开它与自己所有的Person对象的关联即可,Person对象是不会销毁的

}

public Class Window

{

private Menu menu;

public Window()

{

menu = new Menu();

}//可以在这时候创建Menu对象,也可以在之后创建

public void destory()

{

menu.destory();

}//必须同时或者在这之前销毁关联的Menu对象

}

另外有一个差别是组合中的一个对象在同一时刻只能属于一个组成对象,而聚合的一个部分对象可以被多个整体对象聚合,例如一个学生可以在多个学校就读,而一个菜单在同一时刻只能是某个窗口内的对象。

实现关系就比较简单了,指的是一个类元描述了另一个类元保证实现的契约。对类来说,就是一个类实现了一个接口

public interface A

{

public void methodA();

}

public class B implements A

{

public void methodA()

{...}

...

}

一般在面对对象的系统中,尽可能的使用接口来减少类之间的耦合。因为接口没有实现,所以依赖于接口就不会依赖于某种具体实现,例如jdbc里的Connection和ResultSet都是接口,不同数据库厂商的实现可以不一样。

总结一下

1)依赖关系:关系对象出现在局部变量或者方法的参数里,或者关系类的静态方法被调用

2)关联关系:关系对象出现在实例变量中

3)聚合关系:关系对象出现在实例变量中

4)合成关系:关系对象出现在实例变量中

5)Generalization: extends

6)实现: implements

聚合是这样的:学生与所选课程之间的关系就是组合,他们之间在感念上没有必然关系,删掉一门课程,不会影响到学生

组合是这样的:订单和订单条目的关系就是聚合,他们的关系很紧密,删掉一个订单,订单条目也就没有意义了

组合是聚合的一种形式
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: