在画类图的时候,理清类和类之间的关系是重点。类的关系有泛化(Generalization)、实现(Realization)、依赖(Dependency)和关联(Association)。其中关联又分为一般关联关系和聚合关系(Aggregation),合成关系(Composition)。下面我们结合实例理解这些关系。

基本概念

类图(Class Diagram): 类图是面向对象系统建模中最常用和最重要的图,是定义其它图的基础。类图主要是用来显示系统中的类、接口以及它们之间的静态结构和关系的一种静态模型。

类图的3个基本组件:类名、属性、方法。

泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。在类图中使用带三角箭头的实线表示,箭头从子类指向父类。

实现(Realization):在类图中就是接口和实现的关系。这个没什么好讲的。在类图中使用带三角箭头的虚线表示,箭头从实现类指向接口。

依赖(Dependency):对象之间最弱的一种关联方式,是临时性的关联。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。

关联(Association) : 对象之间一种引用关系,比如客户类与订单类之间的关系。这种关系通常使用类的属性表达。关联又分为一般关联、聚合关联与组合关联。后两种在后面分析。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。

聚合(Aggregation) : 表示has-a的关系,是一种不稳定的包含关系。较强于一般关联,有整体与局部的关系,并且没有了整体,局部也可单独存在。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。在类图使用空心的菱形表示,菱形从局部指向整体。

组合(Composition) : 表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。

多重性(Multiplicity) : 通常在关联、聚合、组合中使用。就是代表有多少个关联对象存在。使用数字..星号(数字)表示。如下图,一个割接通知可以关联0个到N个故障单。

聚合和组合的区别

这两个比较难理解,重点说一下。聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。

实例分析

联通客户响应OSS。系统有故障单、业务开通、资源核查、割接、业务重保、网络品质性能等功能模块。现在我们抽出部分需求做为例子讲解。

大家可以参照着类图,好好理解。

1. 通知分为一般通知、割接通知、重保通知。这个是继承关系。
2. NoticeService和实现类NoticeServiceImpl是实现关系。
3. NoticeServiceImpl通过save方法的参数引用Notice,是依赖关系。同时调用了BaseDao完成功能,也是依赖关系。
4. 割接通知和故障单之间通过中间类(通知电路)关联,是一般关联。
5. 重保通知和预案库间是聚合关系。因为预案库可以事先录入,和重保通知没有必然联系,可以独立存在。在系统中是手工从列表中选择。删除重保通知,不影响预案。
6. 割接通知和需求单之间是聚合关系。同理,需求单可以独立于割接通知存在。也就是说删除割接通知,不影响需求单。
7. 通知和回复是组合关系。因为回复不能独立于通知存在。也就是说删除通知,该条通知对应的回复也要级联删除。

原文发布时间为:2018-07-10
本文来自云栖社区合作伙伴“Java杂记”,了解相关信息可以关注“Java杂记”

五分钟看懂UML类图与类的关系详解相关推荐

  1. UML类图之六种基本关系详解

    文章目录 0. 什么是UML? 1. 依赖关系(Dependence) 1.1 什么是依赖关系? 1.2 上代码 1.3 用类图描述关系 1.4 依赖小结 2. 泛化关系(Generalization ...

  2. 3分钟看懂五日均线图!最实用的五日均线图解教程!

    3分钟看懂五日均线图!最实用的五日均线图解教程! 均线并不是技术环境分析的全部内容,但无疑是技术环境中不可或缺的重要组成部分.均线代表的是市场平均成本运行趋势,其重要性在于反映现行价格得到支撑或受到压 ...

  3. 五分钟读懂UML类图

    平时阅读一些远吗分析类文章或是设计应用架构时没少与UML类图打交道.实际上,UML类图中最常用到的元素五分钟就能掌握,下面赶紧来一起认识一下它吧: 一.类的属性的表示方式 在UML类图中,类使用包含类 ...

  4. 五分钟读懂UML类图(转)

    平时阅读一些远吗分析类文章或是设计应用架构时没少与UML类图打交道.实际上,UML类图中最常用到的元素五分钟就能掌握,下面赶紧来一起认识一下它吧: 一.类的属性的表示方式 在UML类图中,类使用包含类 ...

  5. UML设计java程序_利用UML序列图设计Java应用程序详解

    [IT168 技术文章] Java应用程序由许多类所构成,是Java实现面向对象应用程序的核心.类图主要描述Java应用程序中各种类之间的相互静态关系,如类的继承.抽象.接口以及各种关联.要利用UML ...

  6. 一文学会看懂汽车中的传感器电路(图文详解)

    1.加速踏板位置传感器电路识读 大众车系普遍采用电子节气门,取消了加速踏板和节气门之间的拉锁,转而采用加速踏板位置传感器.加速踏板位置传感器向发动机控制单元提供驾驶员操作加速踏板的信息,发动机控制单元 ...

  7. uml 菱形_UML建模之类图常用符号及关系详解!

    在软件开发中,经常会遇到UML建模,而类图作为一种静态的结构图,不仅是系统编码和测试的重要模型,还可以简化人们对系统的理解.因此,理解和知道如何使用UML图就显得尤为重要了!那么,对于UML类图中常用 ...

  8. 什么是嵌入式?你眼中的嵌入式是怎么样的?怎么学嵌入式?教你五分钟看懂嵌入式。

    你眼中的嵌入式是怎么样的? 嵌入式的定义 从技术上来区分嵌入式 嵌入式硬件工程师必备技能 嵌入式驱动工程师必备技能 嵌入式软件开发工程师必备技能 嵌入式系统开发工程师必备技能 总结 嵌入式的定义 IE ...

  9. 五分钟看懂同城小程序是什么,能做什么!

    我们都知道,微信小程序是基于微信这样一个社交平台运行的轻应用,不需要用户下载任何软件,只需要有微信就能够直接使用,非常方便. 微趋道,就是小程序 对于普通商家来说,小程序可谓是营销利器,开发成本低,运 ...

最新文章

  1. CSDN 湘苗培优,打造高素质技术人才
  2. dubbo启动时检查服务
  3. RDIFramework.NET 中多表关联查询分页实例
  4. php怎么把时间戳转成日期格式,php怎么把时间格式转换为时间戳?,时间戳转为日期...
  5. 关于mysql的教学文章_数据库课程教学方法探索论文
  6. 深度卷积神经网络_深度卷积神经网络中的降采样
  7. Python中使用Unicode对中文进行编码和解码
  8. CentOS 6.7安装Spark 1.5.2
  9. C++ 工程实践(3):采用有利于版本管理的代码格式
  10. MPU6050数据分析
  11. 【操作系统】分区分配算法(首次适应算法、最佳适应算法)C语言
  12. 冯言冯语说DSP(二)序列的z变换
  13. 有用但用处不多的html的属性
  14. 发送手机短信验证码-后端、前端(验证码倒计时)
  15. 作业一:数据软件系统的介绍及spss的操作简介
  16. label mpchart 饼图_ECharts饼图属性设置
  17. 为什么用python画图_怎么用python画图
  18. ECharts饼图实例
  19. 融云聊天室属性 kv
  20. Python笔记【八】

热门文章

  1. 查找表包含的页和页所在的表
  2. opencv-车牌区域提取
  3. Skype for Business Server 2015-08-反向代理-发布-统一沟通
  4. MSMQ(Microsoft Message Queue)介绍
  5. java内部类和静态内部类的区别
  6. Struts2 分割字符串标签s:generator
  7. 爬虫,如何防止被ban之策略大集合
  8. MyEclipse Derby数据库服务器使用方法
  9. 《高效程序员的45个习惯》读后感
  10. 最近工作好忙,自己的软件又得落下很长一段时间了~