【软件设计】UML类图怎么看
前言
无论使用哪种语言,都离不开面向过程与面向对象两个流派,而类图是面向对象程序设计中至关重要的一种软件表达形式,如何看懂类图,并设计好的软件架构,是我们作为软件工程师必不可少的技能之一。
今天小黑把类图学习的一些笔记和心得分享出来,供大家参考。
什么是类
了解类图之前,我们需要简单了解一下类的概念
类(Class)封装了数据和行为,是面向对象的重要组成部分,它是具有相同属性、操作、关系的对象集合的总称。
在面向过程设计中,数据和算法组织成为程序。而面向对象中,数据+算法的理论基础并没有改变,虽然整个程序框架由一个个类组成,每一个类都是独立的数据+算法集合。类的设计遵循单一职责原则,只负责自己的私有数据,调用自己的方法(算法)。通过类将程序组织分类,各自负责各自的逻辑,让整个程序有序化,组织化。
什么是类图
类图(Class Diagram)使用出现在系统中的不同类来描述系统的静态结构,它用来描述不同的类以及它们之间的关系。
类图(Class Diagram)使用出现在系统中的不同类来描述系统的静态结构,它用来描述不同的类以及它们之间的关系。
类图在面向对象设计中用于组织不同之间的关系,无论是文本编程还是图形化的程序,面向对象的程序如果脱离类图,都将变的理解吃力。一张明了的类图,可以让你省去阅读程序的诸多烦恼。
近期,小黑仿作AddLabel工具时,如果你只看程序,理清各个类之间的关系和组织逻辑将会耗费大量的时间,而一张类图就可轻易的表述不同类之间的组织关系。
下图是LabVIEW自带的类图关系,当类与类之间使用继承关系时,比较容易理解,而使用组合关系,没有类图辅助,看起来将比较困难
下图是绘制的类图,从图中可以比较清晰的明确各个类之间的关系

如何看类图
在UML类图中,类使用包含类名、属性和操作且带有分隔线的长方形来表示,使用Label的类图作为例子讲解
在该类图中,包含有三部分,分别是类名、类的属性、类的操作
第一部分是类的名称
每一个类都有一个名称,在UML类图中作为类与类之间的区别
对应的LabVIEW代码如下图所示

第二部分为类类的属性
属性是指类的性质,即类的成员变量。一个类可以有任意多个属性,也可以没有属性。类的属性也即作为最小信息单元的数据结构,每一个类都有属于自己的数据结构。
标准的类图属性由以下内容组成
可见性 名称:类型[缺省值]
这里我们表述的Label由text,textcolor,backgroundColor等属性组成
对应LabVIEW中的数据结构保存于Label.ctl中

这里需要说明的是,属性名称前的-号代表可见性 “可见性”表示该属性对于类外的元素而言是否可见,包括公有(public)、私有(private)和受保护(protected)三种,在类图中分别用符号+、-和#表示。
在LabVIEW同样具有不同访问属性的设计,其中如Label.ctl上方显示的红色小钥匙代表私有(private)属性
使用黄色小钥匙的代表受保护的属性(protected)
如果没有钥匙,则代表访问类型为公有(public)
LabVIEW的私有属性确保了类中的数据只能被类内部访问,外部需要通过访问器才可以更改类内部的数据

第三部分为类的方法
类的方法可以通过如下形式表达:
可见性 名称(参数列表) [ : 返回类型]
Label类中由于SetLabelPosition没有返回值,所以省略不写,只表示这是一个公共的方法,并且有传入的Cluster参数
类图与LabVIEW对应关系如下图所示:

类图的组织关系
在类图中,不同的类之间存在着不同的关系,只有使用合适的表达符号才可以表述不同类之间的关系
继承关系
类与类之间的继承关系,可以表征类的基本特性,类图中,AddWireLabel继承了Actor,所以使用继承的符号来连接两个类图

依赖关系
依赖关系指的是一个类在计算的时候用到了另一个类的参数。而这种使用关系是具有偶然性的、、临时性的、非常弱的,但是B类的变化会影响到A;
## 关联关系
关联(Association)关系是类与类之间最常用的一种关系,它是一种结构化关系,用于表示一类对象与另一类对象之间有联系,如汽车和轮胎、师傅和徒弟、班级和学生等等。

关联关系比依赖更强、不存在依赖关系的偶然性、关系也不是临时性的,一般是长期性的,而且双方的关系一般是平等的、关联可以是
- 双向关联
- 单向关联
- 自关联
多重性关联
聚合关系
聚合是关联关系的一种特例,他体现的是整体与部分、拥有的关系,即has-a的关系,此时整体与部分之间是可分离的,他们可以具有各自的生命周期,部分可以属于多个整体对象,也可以为多个整体对象共享
这里的Label相对于Segment就是一种聚合关系,判断依据就是,Label不仅可以作为Segment的Label,也可以作为其他如矩形,Wire的label

### 组合关系
组合也是关联关系的一种特例,他体现的是一种contains-a的关系,这种关系比聚合更强,也称为强聚合;他同样体现整体与部分间的关系,但此时整体与部分是不可分的,整体的生命周期结束也就意味着部分的生命周期结束
这里线和线段的关系就属于组合关系,判断依据就是,如果没有线,线段就不会存在

在Viso中,每一种对应关系都给出了曲线应该具有的表示方法(复合就是组合的意思),有兴趣的可以深入了解

总结
本节作为面向对象基础,向大家介绍了类图的基本识别方法,其他的内容如果感兴趣可以百度或者谷歌相关具体的资料。
后记
小黑最近正在不停的充电中,学习任务比较多,所以没能及时更新相关知识,让大家久等了。后期小黑会给自己制定一些写作计划,保证可以稳定的输出一些文档,期待与大家的互动与交流~
【软件设计】UML类图怎么看的更多相关文章
- Java开发设计——UML类图
Java开发设计——UML类图 摘要:本文主要介绍了UML类图的相关知识. 简介 在UML中,类使用包含类名.属性和操作且带有分隔线的长方形来表示,类图分为三层. 第一层是类的名称,如果是抽象类或接口 ...
- 《GO Home Trash!》UML类图,ER图以及数据库设计
<Go Home Trash!>UML类图 ER图以及数据库中数据表 分析: 这款软件经过我们前期的讨论以及需求分析,确定了用户,客服以及管理员三个实体.在设计UML类图时,对各个实体之间 ...
- UML类图学习总结
1.首先来认识下类图?以及类图的作用 类图(Class diagram)由许多(静态)说明性的模型元素(例如类.包和它们之间的关系,这些元素和它们的内容互相连接)组成.类图可以组织在(并且属于)包中, ...
- UML类图的补充及软件设计原则
UML类图的补充及软件设计原则 UML 从目标系统的不同角度出发,定义了用例图.类图.对象图.状态图.活动图.时序图.协作图.构件图.部署图等 9 种图. 1.uml补充 统一建模语言(Unified ...
- (转)面向对象——UML类图设计
背景:一直以来,对UMl类图的画法不甚理解,但是随着学习的深入,发现熟练掌握UML类图,能够更好理解代码间的逻辑性,而这也是程序设计的基础所在,所以很有必要把UML好好掌握. UML类图新手入门级介绍 ...
- 设计模式学习(二):面向对象设计原则与UML类图
一.UML类图和面向对象设计原则简介 在学习设计模式之前,需要找我一些预备知识,主要包括UML类图和面向对象设计原则. UML类图可用于描述每一个设计模式的结构以及对模式实例进行说明,而模式结构又是设 ...
- 看懂UML类图与时序图
看懂UML类图和时序图 这里不会将UML的各种元素都提到,我只想讲讲类图中各个类之间的关系: 能看懂类图中各个类之间的线条.箭头代表什么意思后,也就足够应对 日常的工作和交流: 同时,我们应该能将类图 ...
- 看懂UML类图和时序图
看懂UML类图和时序图 这里不会将UML的各种元素都提到,我只想讲讲类图中各个类之间的关系: 能看懂类图中各个类之间的线条.箭头代表什么意思后,也就足够应对 日常的工作和交流: 同时,我们应该能将类图 ...
- [转] 看懂UML类图和时序图
PS: 组合关系:实心,一个类A属于另一个类,或多个类,但是类A不能单独存在去使用,A一般是一种抽象的东西 聚合关系:空心,一个类A可以单独存在使用 不论组合聚合,A的方法都会被直接调用. 看懂UML ...
随机推荐
- 详解 ES6 Modules
详解 ES6 Modules 对于新人朋友来说,想要自己去搞定一个ES6开发环境并不是一件容易的事情,因为构建工具的学习本身又是一个非常大的方向,我们需要花费不少的时间才能掌握它. 好在慢慢的开始有大 ...
- BZOJ1096:[ZJOI2007]仓库建设——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1096 L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚.由于这座山处于 ...
- PE格式示意图
- 卡特兰数(Catalan Number) 学习笔记
一.三个简单的问题 1.给定一串长为2n的01序列,其中0和1的数量相等,满足任意前缀中0的个数不少于1的个数,求序列的个数 2.给出一串长为n的序列,按顺序将他们进栈,随意出栈,求最后进出栈的方案 ...
- LibreOJ #6220. sum(数论+构造)
题目大意:在数组中找出一些数,使它们的和能被n整除 这题标签是数学,那我就标题就写数论好了... 显然如果数组中有n的倍数直接取就行. 那假设数组中没有n的倍数,把数组中的数求前缀和后全部%n,会得到 ...
- 【逆序对相关/数学】【P1966】【NOIP2013D1T2】 火柴排队
传送门 Description 涵涵有两盒火柴,每盒装有 $n$ 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间的距离定义为:$ \sum ...
- 细谈select函数(C语言)
Select在Socket编程中还是比较重要的,可是对于初学Socket的人来说都不太爱用Select写程序,他们只是习惯写诸如connect.accept.recv或recvfrom这样的阻塞程序( ...
- Uva-oj Palindromes 暴力
Palindromes Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit Statu ...
- Sublime Text3 安装Markdown
Sublime Text3是一款给力的文本编辑器,通过安装插件可以编辑Markdown文本,在编辑Markdown文本的同时可以实时预览编辑效果. 安装准备: 找到菜单栏:Preferences → ...
- [LeetCode] Binary Tree Level Order Traversal 与 Binary Tree Zigzag Level Order Traversal,两种按层次遍历树的方式,分别两个队列,两个栈实现
Binary Tree Level Order Traversal Given a binary tree, return the level order traversal of its nodes ...