转:

UML类图中的五种关系的耦合强弱比较:依赖<关联<聚合<组合<继承

一、依赖关系:

(一)说明

虚线+箭头

可描述为:Uses a

依赖是类的五种关系中耦合最小的一种关系。

因为在生成代码的时候,这两个关系类都不会增加属性。

(二)依赖关系图与代码的对应关系

(PS:依赖关系:Animal依赖于Water(动物依赖于水))

  1. Public class Animal()
  2. {
  3. Public Animal(){}
  4. }
  5. Public class Water()
  6. {
  7. public Water(){}
  8. }

可以看到生成的两个类的代码中什么都没有添加

(三)思考:

Animal类如何使用Water类呢?或者说依赖关系到底是如何体现的呢?

1、表现形式1

Water类是全局的,则Animal类可以调用它

2、表现形式2

Water类是 Animal类的某个方法中的变量,则Animal类可以调用它。

  1. Public class Animal {
  2. Public void Grownup() {
  3. Water water =null;
  4. }
  5. }

注意1: Water类的生命期,它是当Animal类的GrounUp方法被调用的时候,才被实例化。

注意2:持有Water类的是Animal的一个方法而不是Animal类,这点是最重要的!

3、表现形式3

Water类是作为Animal类中某个方法的参数或者返回值

  1. Public Animal {
  2. Public Water Grownup(Waterwater) {
  3. return null;
  4. }
  5. }

注意: Water类被Animal类的一个方法持有。生命期随着方法的执行结束而结束

二、关联关系

(一)说明

实线+箭头

可描述为:Has a

关联关系用实线,表示类之间的耦合度比依赖强

在生成代码的时候,关联关系的类会增加属性。

(二)关联关系与代码的对应关系

PS:Water类与Climate类关联(水与气候关联)。

  1. Public classWater {
  2. public Climate m_Climate;
  3. public Water(){}
  4. }
  5. Public class Climate {
  6. public Climate() {}
  7. }

可见生成的代码中,Water类的属性中增加了Climate类。

(三)关联关系的种类

关联既有单向关联又有双向关联。

1、单向关联: Water类和Climate类单向关联(如下图),则Water类称为源类,Climate类称为目标类。源类了解目标类的所有的属性和方法,但目标类并不了解源类的信息。

2、双向关联:源类和目标类相互了解彼此的信息。如将Water类和Climate类之间改为双向关联。

  1. Public class Water {
  2. public Climate m_Climate;
  3. public Water(){}
  4. }
  5. Public class Climate {
  6. public Water m_Water;
  7. public Climate() {}
  8. }

可见生成的代码中,两个类的属性都添加了!

(四)思考:

依赖关系和关联关系的区别在哪里?

1、从类的属性是否增加的角度看

(1)发生依赖关系的两个类都不会增加属性。其中的一个类作为另一个类的方法的参数或者返回值,或者是某个方法的变量而已。

(2)发生关联关系的两个类,其中的一个类成为另一个类的属性,而属性是一种更为紧密的耦合,更为长久的持有关系。

2、从关系的生命期角度看:

(1)依赖关系是仅当类的方法被调用时而产生,伴随着方法的结束而结束了。

(2)关联关系是当类实例化的时候即产生,当类销毁的时候,关系结束。相比依赖讲,关联关系的生存期更长。

(五)关联关系的细化:聚合、组合

1、说明

(1)聚合关系,用空心菱形加箭头表示

(2)组合关系,用实心菱形加箭头表示,类之间的耦合关系比聚合强!

2、聚合和组合都是关联关系的一种,到底如何区分二者呢?

(1)聚合和组合生成的代码

(PS:此图表明雁群类是由大雁类聚合而成)

  1. Public classGooseGroup {
  2. public Goose goose;
  3. Public GooseGroup(Goose goose) {
  4. this.goose = goose;
  5. }
  6. }

(PS:此图表明大雁类是由翅膀类组合而成)

  1. Public classGoose {
  2. public Wings wings;
  3. public Goose() {
  4. wings = new Wings();
  5. }
  6. }

(2)构造函数不同

聚合类的构造函数中包含了另一个类作为参数。 雁群类(GooseGroup)的构 造函数中要用到大雁(Goose)作为参数传递进来。大雁类(Goose)可以脱离雁群类而独立存在。

组合类的构造函数中包含了另一个类的实例化。 表明大雁类在实例化之前,一定要先实例化翅膀类(Wings),这两个类紧密的耦合在一起,同生共灭。翅膀类(Wings)是不可以脱离大雁类(Goose)而独立存在。

(3)信息的封装性不同。

在聚合关系中,客户端可以同时了解雁群类和大雁类,因为他们都是独立的。

在组合关系中,客户端只认识大雁类,根本就不知道翅膀类的存在,因为翅膀类被严密的封装在大雁类中。

三、泛化

(一)说明

实线+箭头

可描述为:Is a

泛化也称继承,子类将继承父类的所有属性和方法,并且可以根据需要对父类进行拓展。

(二)泛化关系与代码的对应关系

(PS:Bird类继承Animal类,鸟是一种动物)

  1. Class  Bird :Animal{
  2. }

(三)思考:

1、子类继承父类,真的是继承了父类的所有属性和方法吗?

子类确实是继承了父类的所有属性和方法,只是对于父类的私有类型成员没有访问权限!访问就会报错!

2、泛化和继承是一回事儿吗?

子类继承父类,父类泛化子类。 这两个词是从不同的角度来说的!

3、为什么要多用组合少用继承?

继承和组合各 有优缺点。

类继承是在编译时刻静态定义的,且可直接使用,类继承可以较方便地改变父类的实现。但是类继承也有一些不足之处。首先,因为继承在编译时刻就定义了,所以无法在运行时刻改变从父类继承的实现。更糟的是,父类通常至少定义了子类的部分行为,父类的任何改变都可能影响子类的行为。如果继承下来的实现不适合解决新的问题,则父类必须重写或被其他更适合的类替换。这种依赖关系限制了灵活性并最终限制了复用性。

对象组合是通过获得对其他对象的引用而在运行时刻动态定义的。由于组合要求对象具有良好定义的接口,而且,对象只能通过接口访问,所以我们并不破坏封装性;只要类型一致,运行时刻还可以用一个对象来替代另一个对象;更进一步,因为对象的实现是基于接口写的,所以实现上存在较少的依赖关系。

四、实现关系

虚线+箭头

(PS:WideGoose类实现IFly接口。大雁实现飞翔的接口)

  1. Class WideGoose:Ifly{
  2. }

实现关系重点理解接口的定义

接口(interface),接口是一种特殊的抽象类,这种抽象类中只包含常量和方法的定义,而没有变量和方法的实现。

UML类图五种关系与代码的对应关系的更多相关文章

  1. 转 UML类图几种关系的总结

    UML类图几种关系的总结   在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregati ...

  2. UML类图几种关系的总结(网摘)

    Source link:http://www.open-open.com/lib/view/open1328059700311.html UML类图几种关系的总结 原文出处:[深度开源] 在UML类图 ...

  3. 【转载】UML类图几种关系的总结

    因为有的时候很久不弄UML图,老是忘记几个常见的连接线的意思,这篇完全说转载:UML类图几种关系的总结 在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Real ...

  4. UML类图几种关系的总结

    在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregation),组合(Composit ...

  5. 【转】UML类图几种关系的总结

    在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregation),组合(Composit ...

  6. UML类图几种关系的总结(转)

    原文:http://gjhappyyy.iteye.com/blog/1422515 在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization), ...

  7. 转:UML类图几种关系的总结

    转自:http://www.open-open.com/lib/view/open1328059700311.html 在UML类图中,常见的有以下几种关系: 泛化(Generalization),  ...

  8. UML类图几种关系的总结,泛化 = 实现 > 组合 > 聚合 > 关联 > 依赖

    在UML类图中,常见的有以下几种关系: 泛化(Generalization), 实现(Realization),关联(Association),聚合(Aggregation),组合(Compositi ...

  9. UML类图几种关系的总结[转]

    原文地址:http://www.open-open.com/lib/view/open1328059700311.html 在UML类图中,常见的有以下几种关系: 泛化(Generalization) ...

随机推荐

  1. Effective Java 读书笔记之五 枚举和注解

    Java1.5中引入了两个新的应用类型家族,新的类为枚举类型,新的接口为注解类型. 一.用enum代替int常量 1.枚举值由一组固定的常量组成合法值的类型. 二.用实例域代替序数 1.不要根据枚举的 ...

  2. css3常用标签

    30个最常用css选择器解析   你也许已经掌握了id.class.后台选择器这些基本的css选择器.但这远远不是css的全部.下面向大家系统的解析css中30个最常用的选择器,包括我们最头痛的浏览器 ...

  3. caffe学习系列(7):Blob,layer,Net介绍

    参考:http://www.cnblogs.com/denny402/p/5073427.html

  4. 2-python学习——hello world

    "hello world"是编程界一个经久不衰的例子,几乎所有语言的学习教程都把它当做第一个程序的范例.学习的过程就是再造轮子的过程,千万不要以为有人做过的,就不去学习了. hel ...

  5. 【leetcode】Maximum Gap

    Maximum Gap Given an unsorted array, find the maximum difference between the successive elements in ...

  6. CEF3开发者系列之CEF3入门

    CEF全称Chromium Embedded Framework,是一个基于Google Chromium 的开源项目.Google Chromium项目主要是为Google Chrome应用开发的, ...

  7. 64位win系统上面tomcat6启动不了 window不能再本地计算机启动

    64位的jdk装完之后,jre的bin目录下面没有client文件夹, 而tomcat6.0.20的默认配置启动在client文件夹下面. 所以打开tomcat6w,在java选项界面,取消Use d ...

  8. Java for LeetCode 218 The Skyline Problem【HARD】

    A city's skyline is the outer contour of the silhouette formed by all the buildings in that city whe ...

  9. java入门 第一季3

    运算符:算术运算符,赋值运算符,比较运算符,逻辑运算符,条件运算符 1. 算术运算符: 自增和自减只能用于操作变量,不能直接用于操作数值和常量 % 求余数 2.  赋值运算符 = 赋值运算符为变量或常 ...

  10. WebLogic部署

    1.抓取解压WAR包,放在相应目录下 2.登录部署,激活 http://jingyan.baidu.com/article/c74d6000650d470f6b595d72.html Linux环境中 ...