【软件设计】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 ...
随机推荐
- [NOIP2012]疫情控制 贪心 二分
题面:[NOIP2012]疫情控制 题解: 大体思路很好想,但是有个细节很难想QAQ 首先要求最大时间最小,这种一般都是二分,于是我们二分一个时间,得到一个log. 然后发现一个军队,越往上走肯定可以 ...
- [SHOI2012]回家的路 最短路
---题面--- 题解: 吐槽:找了好久的错,换了n种方法,重构一次代码,,,, 最后发现,,, 数组开小了,其实一开始尝试开大了数组,但唯独没有尝试开大手写队列的数组.... 思路: 有两种方法,这 ...
- Android源码4.4.4_r1下载和编译
系统:ubuntu 16.04.2 TLS 1.源码下载: sudo apt-get install curl curl https://storage.googleapis.com/git-repo ...
- librdkafka 源码分析
http://note.youdao.com/noteshare?id=c7ff510525b4dadaabb6f6a0a72040cc
- 【题解】Weird journey Codeforces 788B 欧拉路
传送门:http://codeforces.com/contest/788/problem/B 好题!好题! 首先图不连通的时候肯定答案是0,我们下面讨论图联通的情况 首先考虑,如果我们每条边都经过两 ...
- mac os x之解决npm安装包失败,或者nodejs工程缺少依赖
在国内做开发,由于各种各样的原因,导致网络总是那么不好,对于我们前端开发者,在使用npm的时候很可能因为网络问题导致包安装失败,然后我们又匆匆启动项目,导致缺少依赖等各种问题,下面将会介绍一个淘宝的n ...
- maven中jar包的maven地址查询
在网站 https://mvnrepository.com/ 中查找.
- vijos 1081 野生动物园 函数式线段树
描述 cjBBteam拥有一个很大的野生动物园.这个动物园坐落在一个狭长的山谷内,这个区域从南到北被划分成N个区域,每个区域都饲养着一头狮子.这些狮子从北到南编号为1,2,3,…,N.每头狮子都有一个 ...
- C11性能之道:标准库优化
1.emplace_back减少内存拷贝和移动 emplace_back能通过参数构造对象,不需要拷贝或者移动内存,相比pusk_back能更好的避免内存的拷贝和移动,使容器插入元素性能得到进一步提升 ...
- redis linux下的开机启动
redis linux下的环境搭建 http://www.cnblogs.com/zsg88/p/8321644.html 安装完redis-4.0.1后设置linux开机自启动. 1.在re ...