UML类图(继承、实现、关联、依赖、组合、聚合),你还傻傻分不清吗?

UML类图


image

「左耳朵梵高」 总第11期


写在最前面的话

声明:本文部分资料摘自维基百科,还有我多年工作的积累和总结。本文很适合作为一个工具,就当是一本UML说明书,请记得收藏哦,在需要用的时候方便查阅。

什么是UML

维基百科对UML的定义:

UML(Unified Modeling Language)是一种开放的方法,用于说明、可视化、构建和编写一个正在开发的、面向对象的、软件密集系统的制品的开放方法。UML展现了一系列最佳工程实践,这些最佳实践在对大规模,复杂系统进行建模方面,特别是在软件架构层次已经被验证有效。

这个语言由葛来迪·布区,伊瓦尔·雅各布森与詹姆士·兰宝于1994年至1995年间,在Rational Software公司中开发,于1996年,又进一步发展。UML集成了Booch,OMT和面向对象程序设计的概念,将这些方法融合为单一的,通用的,并且可以广泛使用的建模语言。UML打算成为可以对并发和分布式系统的标准建模语言。

UML并不是一个工业标准,但在Object Management Group的主持和资助下,UML正在逐渐成为工业标准。OMG之前曾经呼吁业界向其提供有关面向对象的理论及实现的方法,以便制作一个严谨的软件建模语言(Software Modeling Language)。有很多业界的领袖亦真诚地回应OMG,帮助它创建一个业界标准。

从维基百科的定义中,可以总结出几个关键点:

  • UML是一个软件建模语言。是一个事实上的工业标准;

  • UML用于提供面向对象设计的理论和实现方法;

  • UML提供了一系列最佳工程实践,在系统建模、软件架构设计层次十分有效。

进一步,我们可以总结出几个关键字:软件建模语言工业标准面向对象系统建模架构设计最佳时间

在UML系统开发中有三个主要的模型:

  • 功能模型 :从用户的角度展示系统的功能,包括用例图。

  • 对象模型 :采用对象,属性,操作,关联等概念展示系统的结构和基础,包括类图、对象图。

  • 动态模型 :展现系统的内部行为。包括序列图,活动图,状态图。

UML包含了一系列的图,最常用的有用例图、类图、时序图等。本文只会涉及类图 ,其它的图形将在以后的文章中进行介绍。

UML类图详解

类描述

在UML中通常以实线矩形框表示。矩形框中有若干分割线。分别表示类名、属性和方法。如下图所示:

image
  • 类名:图中最上面的矩形框中为类名。如果字体为斜体 ,表示为抽象类 。(图中的上面部分)

  • 属性:类名下边的区域。(图中的中间部分)

  • 方法:(图中的下面部分)

说明:属性和方法前面的“+”、“-”和“#”表示访问级别:

  • +:public

  • -:private

  • #:protected

接口描述

接口 的类图表述与类大致相同,不同的是接口名要添加 Interface 标识,且行为的可见性必须用 "+" 表示。如下图:

image

类和类之间的关系

类之间有六种关系:

  • 继承

  • 实现

  • 关联

  • 依赖

  • 组合

  • 聚合

image

继承(Inherit)

继承 是面向对象语言的三大特性(封装,继承,多态)之一。子类继承父类。

image

UML类图中继承关系使用空心三角形+实线表示。

实现(Implement)

实现 与继承类似,实现类继承接口中的方法。

image

UML类图中实现关系使用空心三角形+虚线表示。

关联

依赖关系通常表现为类的私有属性。

// 企鹅类
public class Penguin {
  // 天气类
  private Climate climate;
}

其UML类图表示如下:

image

UML类图中关联使用实线箭头表示。

依赖

依赖 关系体现为局部变量、方法的形参,或者对静态方法的调用。

public class Programmer {
  public void work(Computer computer){
    
  }
}
image

UML类图中依赖关系使用虚线箭头表示。

以下代码展示了依赖关系的三种具体代码实现:局部变量、方法的形参和对静态方法的调用。

public class Person{
  public void doSomething1(){
    Car car = new Car();//局部变量
    ...
  }
  
  public void doSomething2(Car car){//方法参数
    ...
  }
  
  public void doSomething3(){
    int price = Car.do();//静态方法调用
  }
}

组合

组合 是关联关系的一种,表示一种强的“拥有”关系。体现了严格的部分和整体的关系。部分和整体的生命周期一样。

public class Bird {
  private Wing wing;
  public Bird() {
    this.wing = new Wing();
  }
}
image

UML类图中组合关系使用实心菱形+实线表示。

聚合

聚合 是关联关系的一种,表示一种弱的“拥有”关系。

用Java代码表示大雁是群居动物,每只大雁都属于一个雁群,一个雁群可以有多只大雁。

天气凉了,树叶黄了。
。。。
一群大雁往南飞,一会排成“S”字,一会排成“B”字。
——《秋天》出自人教版小学语文一年级课文

public class WildGooseAggregate {
  private List<WildGoose> wideGooses;
}
image

UML类图中聚合关系使用空心菱形实线表示。

All in One的例子

前面介绍了类之间的6种关系。为了更好地理解这6种关系。下面使用一个完整的例子(汽车)。该示例中包含了这6种关系。

image

说明:

  • 车的类图结构为,表示车是一个抽象类;

  • 它有两个继承类:小汽车和自行车;它们之间的关系为实现 关系,使用带空心箭头的虚线表示;

  • 小汽车为与SUV之间也是继承 关系,它们之间的关系为泛化关系,使用带空心箭头的实线表示;

  • 小汽车与发动机之间是组合 关系,使用带实心箭头的实线表示;

  • 学生与班级之间是聚合 关系,使用带空心箭头的实线表示;

  • 学生与身份证之间为关联 关系,使用一根实线表示;

  • 学生上学需要用到自行车,与自行车是一种依赖 关系,使用带箭头的虚线表示;


每日一画:鸢尾花

我是左耳朵梵高,北理工毕业,现任某金融咨询公司首席架构师,曾在阿里巴巴中间件团队任职。沉浸软件行业十余年,相信技术能改变世界。译有《你真的会写代码吗?》

坚持输出技术干货,职场心得和读书感悟。欢迎关注公众号左耳朵梵高 ,和我一起持续学习,终生成长。


推荐阅读

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容