UML类图与类图中的关系
以下内容摘自《Java与模式》
在类与类之间,会有连线指明它们之间的关系。类和类、类和接口、接口和接口之间可以建立以下几种关系:一般化关系、关联关系、聚合关系、合成关系和依赖关系,这几种关系都是静态的。
一般化关系
一般化(Generalization)关系表示类与类之间的继承关系,接口与接口之间的继承关系,或类对接口的实现关系。一般化的关系是从子类指向父类的,或从实现接口的类指向被实现的接口,与继承或实现的方向相反,如下图所示。

一般化关系在Java语言中可以直接翻译为关键字extends(泛化)和implements(实现)。前者描述类与类之间、接口与接口之间的一般化关系,后者描述与接口之间的一般化关系。
关联关系
关联(Association)关系是类与类之间的联接,它使一个类知道另一个类的属性和方法。关联可以是双向的,也可以是单向的。双向的关联可以有两个箭头或者没有箭头。单向的关联有一个箭头,表示关联的方向,如下图所示。单向的关联更为普遍,通常不鼓励使用双向的关联。

在Java的语言里,关联关系是使用实例变量实现的。比如在上面的Driver类中,就出现了一个类型为Car的实例变量,这个变量实现了这两个类之间的关联关系。每一个关联都有一个名字,在上面的例子里,关联的名字是Driver。
每一个关联都有两个端点,每一个端点都可以有一个角色名,显示出关联的本质。一个关联可以有一个方向箭头,表明遍历或者查询的方向。
在每一个关联的端点,还可以有一个基数(Multiplicity),表明这一端的类可以有几个实例。比如,唐僧和他的徒弟形成一个关联关系,在这个关联里面,唐僧只能有一个,而徒弟可以有好几个,如下图所示。

一个关联关系往往可以进一步确定为聚合关系或者合成关系。比如唐僧与他的徒弟的关系就可以进一步确定为聚合关系。
聚合关系
聚合(Aggregation)关系是关联关系的一种,是强的关联关系。聚合是整体和个体之间的关系。例如,汽车类与引擎类、轮胎类,以及其他的零件类之间的关系便是整体和个体的关系。一个汽车对象是由一个引擎对象、四个轮胎对象组成的,如下图所示。

与关联关系一样,聚合关系也是通过实例变量实现的。以上面的例子为例,Car类中应当有一个类型为Engine的属性和一个类型为Tire的数组属性。但是,关联关系所涉及的两个类是处在同一层次上的,而在聚合关系中,两个类是处在不平等层次上的,一个代表整体,另一个代表部分。
关联与聚合仅仅从Java语法上是分辨不出的,需要考察所涉及的类之间的逻辑关系。如果不是很确定一个关系是不是聚合关系,可以将之设置为关联关系。
合成关系
合成(Composition)关系是关联关系的一种,是比聚合关系强的关系。它要求普通的聚合关系中代表整体的对象负责代表部分的对象的生命周期,合成关系是不能共享的。
代表整体的对象需要负责保持部分对象的存活,在一些情况下负责将代表部分的对象湮灭掉。代表整体的对象可以将代表部分的对象传递给另一个对象,由后者负责此对象的生命周期。聚合关系和合成关系的类图如下图所示。

在上面的类图中,显示了MonkeyKing以及他的四肢(Limb)和他的金箍棒(GoldRingedStaff)之间的关系。可以看出,MonkeyKing与GoldRingedStaff之间是聚合关系;而MonkeyKing与Limb之间的关系比前者更强,是合成关系,因为MonkeyKing的四肢完全有他自己负责,并且不能共享。
如果不能确定一个关系是不是合成关系,可以将之设置为聚合关系,甚至是关联关系。
依赖关系
依赖(Dependency)也是类与类之间的连接,依赖总是单向的。依赖关系表示一个类依赖于另一个类的定义。一个人(Person)可以买车(Car)和房子(House),Person类依赖于Car类和House类,如下图所示。

在上面的例子里,Person类依赖于Car类和House类的定义,因为Person类引用了Car和House。与关联关系不同的是,Person类里并没有Car和House类型的属性,Car和House的实例是以参量的方式传入到buy()方法中去的。其源代码如下所示。
public class Person{
public void buy(Car car){
....
}
public void buy(House house){
....
}
}
一般而言,依赖关系在Java语言中体现为局域变量、方法的参量,以及对静态方法的调用。换言之,如果一个方法的参量是另一个类B的实例,那么这个方法所在的类A依赖于类B。如果类A调用另一个类B的静态方法,那么类A依赖于类B。
如果类B出现在类A的实例变量中,那么类A与类B的关系就超越了依赖关系,,而变成了某一种关联关系。
每一个依赖关系都可以有一个名字。在上面的例子里,两个依赖关系的名字都是Buys。

UML类图与类图中的关系的更多相关文章
- UML类图中的关系和表示方法
类图是用来描述程序中的类以及它们之间的关系的,使用类图可以帮助我们简化对系统的理解.在UML类图中比较常见的关系有六种,它们分别是:依赖.关联.聚合.组合.泛化.实现,这六种关系中类之间的紧密程度是依 ...
- uml类图和er图中主外键的表示区别
在er图也就是数据库中,无论是mysql/oracle都是从表引用主表的pk作为外键. 而在uml类图表示法中,他们的顺序则刚好相反,从主对象导向到子对象,如下: 主体是资金借款方,征信信息和资金借款 ...
- UML类图中的关系表示
UML类图中的关系和表示方法 类图是用来描述程序中的类以及它们之间的关系的,使用类图可以帮助我们简化对系统的理解.在UML类图中比较常见的关系有六种,它们分别是:依赖.关联.聚合.组合.泛化.实现,这 ...
- 3.UML中的类图及类图之间的关系
统一建模语言简介 统一建模语言(Unified Modeling Language,UML)是用来设计软件蓝图的可视化建模语言,1997 年被国际对象管理组织(OMG)采纳为面向对象的建模语言的国际标 ...
- GOF 的23种JAVA常用设计模式总结 02 UML中的类图与类图之间的关系
统一建模语言UML 统一建模语言(Unified Modeling Language,UML)是用来设计软件蓝图的可视化建模语言,1997 年被国际对象管理组织(OMG)采纳为面向对象的建模语言的国际 ...
- UML中的类图及类图之间的关系
统一建模语言简介 统一建模语言(Unified Modeling Language,UML)是用来设计软件蓝图的可视化建模语言,1997 年被国际对象管理组织(OMG)采纳为面向对象的建模语言的国际标 ...
- 【uml】之类图中的关系 标签: uml图形类 2014-11-29 09:02 1198人阅读 评论(23)
uml早就画完了图,但是自己迟迟没有总结,因为总觉的自己把握的不到位,虽然现在也还是不到位,废话少说,上篇博客总结了用例图中的几种关系,这篇就讨论一下类图中的几种关系. 在uml的所有图中,就我目前的 ...
- UML基础系列:类图
类图描述系统中类的静态结构,它不仅定义系统中的类,描述类之间的联系,如关联.依赖.聚合等,还包括类的内部结构(类的属性和操作).类图描述的是静态关系,在系统的整个生命周期中都是有效的.对象图是类图的实 ...
- UML 用例图、顺序图、状态图、类图、包图、协作图、流程图
用例图.顺序图.状态图.类图.包图.协作图 面向对象的问题的处理的关键是建模问题.建模可以把在复杂世界的许多重要的细节给抽象出.许多建模工具封装了UML(也就是Unified Modeling La ...
随机推荐
- C++学习笔记11-面向对象2
1. 仅仅能初始化直接基类 一个类仅仅能初始化自己的直接基类.直接就是在派生列表中指定的类.假设类C 从类B 派生,类B 从类A 派生,则B 是C 的直接基类.尽管每一个C 类对象包括一个A 类部 ...
- 在IIS中给某一个网站添加binding的坑
以http为例, 假如ip地址从局域网的地址172.31.212.20改为127.0.0.1 但是网站没法访问了http://172.31.212.20/chile.backoffice/ 必须通过 ...
- python note #3
Hello, guys! I found it pretty difficult to get my content according to my key words. So in this not ...
- cogs 1500. 误差曲线
1500. 误差曲线 ★★ 输入文件:errorcurves.in 输出文件:errorcurves.out 评测插件时间限制:1 s 内存限制:256 MB [题目描述] Josep ...
- docker on spark
从docker 仓库 pull 镜像 docker pull sequenceiq/spark:1.4.0 构建 docker 镜像 docker build –rm -t sequenceiq/sp ...
- js正則表達式--验证表单
检測手机号码:/0? (13|14|15|18)[0-9]{9}/ 检測username:(数字,英文,汉字.下划线.中横线):/^[A-Za-z0-9_\-\u4e00-\u9fa5]+$/ pas ...
- osgi实战学习之路:1. ant+bnd+felix搭建osgi之HelloWorld
开发环境分为三个部份 osgi_provider: bundle开发环境,对外提供服务 osgi_consumer: 引用其他bundle osgi_main: 执行測试 项目主要内容 : commo ...
- Lua 是一个小巧的脚本语言
Redis进阶实践之七Redis和Lua初步整合使用 一.引言 Redis学了一段时间了,基本的东西都没问题了.从今天开始讲写一些redis和lua脚本的相关的东西,lua这个脚本是一个好东西,可以运 ...
- 3.Maven之(三)Maven插件
转自:https://yq.aliyun.com/ziliao/312162 Maven本质上是一个插件框架,它的核心并不执行任何具体的构建任务,所有这些任务都交给插件来完成,像编译是通过maven- ...
- Elasticsearch之marvel(集群管理、监控)插件安装之后的浏览详解
前提 Elasticsearch之插件介绍及安装 https://i.cnblogs.com/posts?categoryid=950999&page=2 (强烈建议,从头开始看) 比如,我 ...