UML图关联关系
关联关系共有四种,由弱至强依次是:依赖 <关联 < 聚合<组合
依赖
从代码层面上看,被依赖的类B作为参数被类A在某个方法中使用。这种使用关系是偶然性的,非常弱的。B类的变化会影响到A类。
关联
从代码层面上看,被关联类B以类属性的形式出现在关联类A中,也可能是关联类A引用了一个类型为关联类B的全局变量。它体现的是一种强关联关系。
聚合关系
聚合是关联关系的一种特例,他体现的是整体与部分、拥有的关系,即has-a的关系,此时整体与部分之间是可分离的,他们可以具有各自的生命周期,部分可以属于多个整体对象,也可以为多个整体对象共享;
聚合也转换成Java中的一个实例作用域变量。因而,从代码层面无法区分他们,从语义层面上分析是:聚合暗示着整体比局部处于一个更高的级别,而关联表示两个类在概念上处于相同的级别。
组合关系
组合也是关联关系的一种特例,他体现的是一种contains-a的关系,这种关系比聚合更强,也称为强聚合;他同样体现整体与部分间的关系,但此时整体与部分是不可分的,整体的生命周期结束也就意味着部分的生命周期结束;和关联关系是一致的,只能从语义级别来区分:
暗示“局部”在“整体”内部的生存期职责。合成是非共享的。所以,虽然局部不一定要随整体的销毁而被销毁,但整体要么负责保持局 部的存活状态,要么负责将其销毁。局部不可与其他整体共享。
总结:实线比虚线的关联关系都要强,实心的菱形比空心的菱形关联关系要强。
另:
- 空心三角形+实线表示继承关系;
- 空心三角形+虚线表示实现关系;
- 实心三角形+虚线(最近在java编程思想中看到的一种UML线)大概是生产者和被生产者的关系吧;