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

类与类关系的UML图与代码表现

2013-07-21 09:57 459 查看
类与类之间的关系对于理解面向对象具有很重要的作用,以前在面试的时候也经常被问到这个问题,在这里我就介绍一下。

类与类之间存在以下关系:

(1)泛化(Generalization)

(2)关联(Association)

(3)依赖(Dependency)

(4)聚合(Aggregation)


UML图与应用代码例子:

1.泛化(Generalization)

[泛化]

表示类与类之间的继承关系,接口与接口之间的继承关系,或类对接口的实现关系。一般化的关系是从子类指向父类的,与继承或实现的方法相反。

[具体表现]

父类 父类实例=new 子类()

[UML图](图1.1)



图1.1 Animal类与Tiger类,Dog类的泛化关系

[代码表现]





class Animal{}

class Tiger extends Animal{}

public class Test

{

public void test()

{

Animal a=new Tiger();

}

}



[b]2.依赖(Dependency)

[依赖]

对于两个相对独立的对象,当一个对象负责构造另一个对象的实例,或者依赖另一个对象的服务时,这两个对象之间主要体现为依赖关系。

[具体表现]

依赖关系表现在局部变量,方法的参数,以及对静态方法的调用

[现实例子]

比如说你要去拧螺丝,你是不是要借助(也就是依赖)螺丝刀(Screwdriver)来帮助你完成拧螺丝(screw)的工作

[UML表现](图1.2)

[/b]





图1.2 Person类与Screwdriver类的依赖关系

[代码表现]




public class Person{

/** 拧螺丝 */

public void screw(Screwdriver screwdriver){


screwdriver.screw();

}

}

[b]

[b]3.关联(Association)

[关联]

对于两个相对独立的对象,当一个对象的实例与另一个对象的一些特定实例存在固定的对应关系时,这两个对象之间为关联关系。

[具体表现]

关联关系是使用实例变量来实现

[现实例子]

比如客户和订单,每个订单对应特定的客户,每个客户对应一些特定的订单;再例如公司和员工,每个公司对应一些特定的员工,每个员工对应一特定的公司

[UML图] (图1.3)



[b]图1.3
公司和员工的关联关系

[代码表现][/b][/b][/b]



public class Company{

private Employee employee;

public Employee getEmployee(){

return employee;

}

public void setEmployee(Employee employee){


this.employee=employee;

}

//公司运作

public void run(){

employee.startWorking();

}

}

[b][b](4)聚合(Aggregation)

[聚合]

当对象A被加入到对象B中,成为对象B的组成部分时,对象B和对象A之间为聚集关系。聚合是关联关系的一种,是较强的关联关系,强调的是整体与部分之间的关系。

[具体表现]

与关联关系一样,聚合关系也是通过实例变量来实现这样关系的。关联关系和聚合关系来语法上是没办法区分的,从语义上才能更好的区分两者的区别。

[关联与聚合的区别]

(1)关联关系所涉及的两个对象是处在同一个层次上的。比如人和自行车就是一种关联关系,而不是聚合关系,因为人不是由自行车组成的。

聚合关系涉及的两个对象处于不平等的层次上,一个代表整体,一个代表部分。比如电脑和它的显示器、键盘、主板以及内存就是聚集关系,因为主板是电脑的组成部分。

(2)对于具有聚集关系(尤其是强聚集关系)的两个对象,整体对象会制约它的组成对象的生命周期。部分类的对象不能单独存在,它的生命周期依赖于整体类的对象的生命周期,当整体消失,部分也就随之消失。比如张三的电脑被偷了,那么电脑的所有组件也不存在了,除非张三事先把一些电脑的组件(比如硬盘和内存)拆了下来。

[UML图](图1.4)



[b]图1.3 电脑和组件的聚合关系

[代码表现]
[/b][/b][/b]



public class Computer{

private CPU cpu;

public CPU getCPU(){

return cpu;

}

public void setCPU(CPU cpu){

this.cpu=cpu;

}

//开启电脑

public void start(){

//cpu运作

cpu.run();

}

}

[b]

[b][参考资料]

[/b][/b]
[b][b]1.《Java与模式》(阎宏 编著) 第2章 统一建模语言UML简介[/b][/b]





类之间的关系

<!--[if !supportLists]-->1. <!--[endif]-->种类: Generalization(泛化),Dependency(依赖关系)、Association(关联关系)、Aggregation(聚合关系)、Composition(合成关系)。

<!--[if !supportLists]-->2. <!--[endif]-->其中Aggregation(聚合关系)、Composition(合成关系)属于Association(关联关系),是特殊的Association关联关系。

<!--[if !supportLists]-->3. <!--[endif]-->Generalization(泛化)表现为继承或实现关系(is a)。具体形式为类与类之间的继承关系,接口与接口之间的继承关系,类对接口的实现关系。

<!--[if !vml]-->



<!--[endif]-->

<!--[if !supportLists]-->4. <!--[endif]-->Association关联关系表现为变量(has a )。类与类之间的联接,它使一个类知道另一个类的属性和方法。例如如果A依赖于B,则B体现为A的全局变量。关联关系有双向关联和单向关联。双向关联:两个类都知道另一个类的公共属性和操作。单向关联:只有一个类知道另外一个类的公共属性和操作。大多数关联应该是单向的,单向关系更容易建立和维护,有助于寻找可服用的类。



<!--[if !vml]-->

<!--[endif]-->

<!--[if !supportLists]-->5. <!--[endif]-->Aggregation(聚合关系) 是关联关系的一种,是强的关联关系。聚合关系是整体和个体的关系。普通关联关系的两个类处于同一层次上,而聚合关系的两个类处于不同的层次,一个是整体,一个是部分。同时,是一种弱的“拥有”关系。体现的是A对象可以包含B对象,但B对象不是A对象的组成部分。具体表现为,如果A由B聚合成,表现为A包含有B的全局对象,但是B对象可以不在A创建的时刻创建。

<!--[if !vml]-->

<!--[endif]-->

<!--[if !supportLists]-->6. <!--[endif]-->Composition(组合关系)是关联关系的一种,是比聚合关系强的关系。它要求普通的聚合关系中代表整体的对象负责代表部分的对象的生命周期。Composition(组合关系)是一种强的“拥有”关系,体现了严格的部分和整体的关系,部分和整体的生命周期一致。如果A由B组成,表现为A包含有B的全局对象,并且B对象在A创建的时刻创建。

<!--[if !vml]-->

<!--[endif]-->

<!--[if !supportLists]-->7. <!--[endif]-->Dependency(依赖关系)表现为函数中的参数(use a)。是类与类之间的连接,表示一个类依赖于另一个类的定义,其中一个类的变化将影响另外一个类。例如如果A依赖于B,则B体现为局部变量,方法的参数、或静态方法的调用。

<!--[if !vml]-->

<!--[endif]-->

<!--[if !supportLists]-->8. <!--[endif]--> Helios 2008-1-11
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: