Understanding UML in seconds
UML 是一种分析设计语言,也就是一种建模语言。
UML结构解析
UML其结构主要包括以下几个部分:
- 视图(View)
多个图形组成的集合; - 图(Diagram)
图的种类有13种图,但常用的也就两种(1.需求用例图,2.开发类图); - 模型元素(Model Element)
如类、对象、消息以及这些概念之间的关系,如关联关系、依赖关系、泛化关系等; - 通用机制(General Mechanism)
UML提供的通用机制为模型元素提供额外的注释、信息和语义(没啥用);
开发类图
类图(Class Diagram)主要用来描述不同的类以及它们之间的关系。
类图的三段式结构为:
| 类名 |
|---|
| 类的属性 |
| 类的操作 |
类图示例

对应的Java代码

观察后发现,图和代码的差别不大,无非是类型写在变量后面而已。
UML规定类属性的表示方式为:

UML规定类操作的表示方式为:

注意:如果是构造方法,则无返回类型。
其中:可见性表示该属性对于类外的元素而言是否可见,包括:
- 公有(public), 在类图中分别用符号
+表示; - 私有(private), 在类图中分别用符号
-表示; - 受保护(protected),在类图中分别用符号
#表示;
这个元素或这个方法对这个类及其子类的其他元素可见。 - 包可见性,对同一个包中的其他元素可见,在类图中分别用符号
*表示;
Java用protected修饰类成员时,该成员可被其所属类的子类以及与其所属类处于同一包中的其他类所访问。
类图间的关系
一共九种关联关系,他们的符号可以记不住,这个没关系,用到再回来查。但是,他们各个图间的关系概念得分辨明晰,不要有含混不明的地方。
- 关联关系(有6种)
- 1.1 双向关联
- 默认情况下,关联是双向的;
- 在UML种用一个根实线连接两个类表示。
- 1.2 单向关联
- 类的关联关系也可以是单向的,在UML中单向关联用带箭头的实线表示。
- 1.3 自关联
- 在系统中可能会存在一些类的属性对象类型为该类本身,这种特殊的关联关系称为自关联。
- 1.4 多重关联
- 表示两个关联对象在数量上的对应关系;
- 在UML中,对象之间的多重性可以直接在关联直线上用一个数字或一个数字范围表示。
- 1.5 聚合关系(Aggregation)
- 聚合关系表示整体与部分的关系;
- 组合关系与聚合关系的区别在于生命周期的管理。在聚合关系中,整体对象和部分对象之间的关联是比较宽松的,部分对象可以独立存在而不受整体对象的控制。
- 在UML中,聚合关系用带空心菱形的直线表示。
- 1.6 组合关系(Composition)
- 组合关系也表示类之间整体和部分的关系;
- 组合关系与聚合关系的区别在于生命周期的管理。在组合关系中,整体对象拥有和管理部分对象的全生命周期;
- 在UML中,组合关系用带实心菱形的直线表示;
- 1.1 双向关联
- 依赖关系
- 依赖(Dependency)关系是一种使用关系;
- 大多数情况下,依赖关系体现在某个类的方法使用另一个类的对象作为参数。
- 在UML中,依赖关系用带箭头的虚线表示,由依赖的一方指向被依赖的一方。
- 泛化关系
- 泛化(Generalization)关系也就是继承关系,用于描述父类与子类之间的关系;
- 在UML中,泛化关系用带空心三角形的直线来表示。
- 接口与实现关系
- 在接口中,通常没有属性,而且所有的操作都是抽象的,只有操作的声明,没有操作的实现;
- 接口之间也可以有与类之间关系类似的继承关系和依赖关系,但是接口和类之间还存在一种实现(Realization)关系。在这种关系中,类实现了接口,类中的操作实现了接口中所声明的操作。
- 在UML中,类与接口之间的实现关系用带空心三角形的虚线来表示。
双向关联
- 双向关联类似 我拥有你,你也拥有我;
- 在UML种用一个根实线连接两个类表示。
例如,顾客(Customer)购买商品(Product)并拥有商品,反之,卖出的商品总有某个顾客与之相关联。因此,Customer类和Product类之间具有双向关联关系,如下图。

public class Customer {
private Product[] products;
}
public class Product {
private Customer customer;
}
单向关联
- 类的关联关系也可以是单向的,就类似 我拥有你,但你不能拥有我;
- 在UML中单向关联用带箭头的实线表示。

public class Customer {
private Address address;
}
public class Address {}
自关联
- 这个也是单向关联,只是指向的不是别人,是自己。
- 在系统中可能会存在一些类的属性对象类型为该类本身,这种特殊的关联关系称为自关联。
- 例如,一个节点类(Node)的成员又是节点Node类型的对象,

public class Node {
private Node node;
}
多重性关联
这个应该是最复杂的,需要好好看看;
- 又称为重数性(Multiplicity)关联关系,表示两个关联对象在数量上的对应关系。
- 多重性应用于关联的目标端,说明源类的每个实例与目标类实例的连接个数。除非显式说明,否则关系的多重性就是未指定的。
- 在UML类图中,关系连线的两端有时会有1..1、*..1等符号,通过下图来做一个说明。
用一个数字或一个数字范围表示, 这里的数字范围一遍指符号,下面有说明表格。
符号说明:

例如:一个界面(Form)可以拥有零个或多个按钮(Button),但是一个按钮只能属于一个界面,因此,一个Form类的对象可以与零个或多个Button类的对象相关联,但一个Button类的对象只能与一个Form类的对象关联,如下图:

对应的Java代码:
public class Form {
private Button[] buttons; //定义一个集合对象
}
public class Button {}
注意: 类之间的多重性有时会直接在关系连线上用一个数字表示,其实这种是不严谨的表示法,
多重性描述的是关系连线的两端,自然要将两端的范围都描述清楚,只写一个数字,会让人不清楚是头还是尾,引起混乱!
聚合关系
- 是一种描述 整体与成员间的关系;
- 在聚合关系中,成员对象是整体对象的一部分,但是成员对象可以脱离整体对象独立存在;
- 简而言之,整体死去了,成员还活着;
- 在UML中,聚合关系用带空心菱形的直线表示。

在代码实现聚合关系时,成员对象通常作为构造方法、Setter\Getter方法或业务方法的参数注入到整体对象中,对应的Java代码片段如下:
public class Car {
private Engine engine;
//构造注入
public Car(Engine engine) {
this.engine = engine;
}
//设值注入
public void setEngine(Engine engine) {
this.engine = engine;
}
}
public class Engine {
// ...
}
组合关系
- 是一种描述 整体与成员间的关系;
- 在组合关系中整体对象可以控制成员对象的生命周期,一旦整体对象不存在,成员对象也将不存在,成员对象与整体对象之间具有同生共死的关系
- 简而言之,整体死去了,成员也死了;
- 在UML中,组合关系用带实心菱形的直线表示;
例如:人的头(Head)与嘴巴(Mouth),嘴巴是头的组成部分之一,而且如果头没了,嘴巴也就没了,因此头和嘴巴是组合关系。

public class Head {
private Mouth mouth;
public Head() {
this.mouth = new Mouth(); //实例化成员类
}
}
public class Mouth {
// ...
}
依赖关系案例
在UML中,依赖关系用带箭头的虚线表示,由依赖的一方指向被依赖的一方。

对应的Java代码:
public class Driver {
public void drive(Car car){
car.move();
}
}
public class Car {
public void move(){
// ...
}
}
泛化关系案例
在UML中,泛化关系用带空心三角形的直线来表示。

对应的Java代码:
//父类
public class Person (
protected String name;
protected int age;
public void move( ) {
// ...
}
public void say( ) {
// ...
}
}
//子类
public class Student extends Person {
private String teacherNo;
public void study( ) {
// ...
}
}
//子类
public class Teacher extends Person {
private String teacherNo;
public void teach() {
// ...
}
}
接口与实现关系案例
在UML中,类与接口之间的实现关系用带空心三角形的虚线来表示。

对应的Java代码
public interface Vehicle {
public void move()
}
public class Ship implements Vehicle {
public void move(){
// ...
}
}
public class Car implements Vehicle {
public void move() {
// ...
}
}
Understanding UML in seconds的更多相关文章
- Game Development Patterns and Best Practices (John P. Doran / Matt Casanova 著)
https://github.com/PacktPublishing/Game-Development-Patterns-and-Best-Practices https://github.com/m ...
- Linux 日志报错 xxx blocked for more than 120 seconds
监控作业发现一台服务器(Red Hat Enterprise Linux Server release 5.7)从凌晨1:32开始,有一小段时间无法响应,数据库也连接不上,后面又正常了.早上检查了监听 ...
- I/O requests taking longer than 15 seconds to complete on file I/O瓶颈问题
I/O requests taking longer than 15 seconds to complete on file I/O瓶颈问题 http://mssqlwiki.com/2012/08/ ...
- UML中关联(Association)、聚合(Aggregation)和合成(Composition)之间的区别
本文为 Dennis Gao 原创技术文章,发表于博客园博客,未经作者本人允许禁止任何形式的转载. 现在,我们需要设计一个项目管理系统,目前我们收集到了如下这些需求: REQ1:一个项目内有多名项目成 ...
- Understanding CMS GC Logs--转载
原文地址:https://blogs.oracle.com/poonam/entry/understanding_cms_gc_logs Understanding CMS GC Logs By Po ...
- Understanding G1 GC Logs--转载
原文地址:https://blogs.oracle.com/poonam/entry/understanding_g1_gc_logs Understanding G1 GC Logs By Poon ...
- (转)The 9 Deep Learning Papers You Need To Know About (Understanding CNNs Part 3)
Adit Deshpande CS Undergrad at UCLA ('19) Blog About The 9 Deep Learning Papers You Need To Know Abo ...
- Understanding Asynchronous IO With Python 3.4's Asyncio And Node.js
[转自]http://sahandsaba.com/understanding-asyncio-node-js-python-3-4.html Introduction I spent this su ...
- Understanding Convolution in Deep Learning
Understanding Convolution in Deep Learning Convolution is probably the most important concept in dee ...
- The Guide To Understanding mysqlreport
The Guide To Understanding mysqlreport This guide to understanding mysqlreport explains everything t ...
随机推荐
- odoo开发教程十:Actions
actions定义了系统对于用户的操作的响应:登录.按钮.选择项目等. 一:窗口action(ir.actions.act_window ) 最常用的action类型,用于将model的数据展示出来. ...
- DevOps| 研发效能和PMO如何合作共赢?
项目经理(PMO)对于大组织.跨团队高效协同有着不可替代的作用.跳出组织架构的束缚,横向推动公司级别的大项目向前推进,跟进进展和拿到结果,PMO的小伙伴有着独特的优势. 我之前写过小团队如何高效协作的 ...
- Redis缓存同步1-策略介绍
缓存数据同步策略示意图 在大多数情况下,我们通过浏览器查询到的数据都是缓存数据,如果缓存数据与数据库的数据存在较大差异的话,可能会产生比较严重的后果的.所以,我们应该也必须保证数据库数据.缓存数据的一 ...
- 详解Django请求与响应:深入理解Web Http交互的核心机制
本文深入探讨了 Django 中的请求与响应处理,从 Django 请求和响应的基础知识.生命周期,到 HttpRequest 和 HttpResponse 对象的详细介绍.同时,讨论了 Django ...
- 【Python】Locust持续优化:InfluxDB与Grafana实现数据持久化与可视化分析
前言 在进行性能测试时,我们需要对测试结果进行监控和分析,以便于及时发现问题并进行优化. Locust在内存中维护了一个时间序列数据结构,用于存储每个事件的统计信息. 这个数据结构允许我们在Chart ...
- Chrome浏览器,有道云笔记的网页剪报需要多次登录且收藏失败报错
报错代码 {"canTryAgain":false,"scope":"SECURITY","error":"2 ...
- Day04_Java_作业
A:选择题 1.下列哪个答案与show不是方法重载(b ). class Demo { void show(int a,int b,float c){} } A.void show(int a,flo ...
- elasticSearch初步学习反思
转自自己的qq空间 2022年11月29日 每次找到新技术就会发癫 把业务整理完了 看着elasticSearch开始发癫 TM的把所有的一切都塞给它 反正全标记索引要啥拿啥 狠狠地获取就完了 思来想 ...
- Vue: 在vscode中添加vue的代码片段
创建vue文件模板 打开vscode,文件–>首选项->用户代码片段,在弹出的搜索框中输入vue,回车 删除原内容,将如下内容粘贴 { "Print to console&quo ...
- 牛客小白月赛64 C题 题解
题目链接 题意描述 这一题的意思其实就是,让你构造一个\(n * k\)的矩阵,使得第 i 列的总和为 i ,同时使得:每一列的任意两个数之间的差不大于1,且任意两行之间的总和差不大于1. \(1 \ ...