一、基本概念
- UML:统一建模语言(英语:Unified Modeling Language,缩写 UML)是非专利的第三代建模和规约语言。UML可以干很多事,画各种各样的逻辑图,这里只关心它在类图中的使用。
- 类图的主要作用是理清类和类之间的关系,是面向对象系统建模中最常用和最重要的图。
-
类图有三个组件:类名、属性、方法。如下图
-
泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。在类图中使用带三角箭头的实线表示,箭头从子类指向父类。
-
实现(Realization):在类图中就是接口和实现的关系。这个没什么好讲的。在类图中使用带三角箭头的虚线表示,箭头从实现类指向接口。
-
依赖(Dependency):对象之间最弱的一种关联方式,是临时性的关联。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。
-
关联(Association) : 对象之间一种引用关系,比如客户类与订单类之间的关系。这种关系通常使用类的属性表达。关联又分为一般关联、聚合关联与组合关联。后两种在后面分析。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。
-
聚合(Aggregation) : 表示has-a的关系,是一种不稳定的包含关系。较强于一般关联,有整体与局部的关系,并且没有了整体,局部也可单独存在。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。在类图使用空心的菱形表示,菱形从局部指向整体。
-
组合(Composition) : 表示contains-a的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。
-
多重性(Multiplicity) : 通常在关联、聚合、组合中使用。就是代表有多少个关联对象存在。使用数字..星号(数字)表示。如下图,一个割接通知可以关联0个到N个故障单。
-
下面来一张类图,大家自己体会一下上面的概念已经逻辑关系:
二、绘制UML类图
画UML图的工具大致可以分为两类,一类是专业的绘图工具,带了画UML的功能,如Visio、Dia;另一类是专门用来制作UML图的,如ArgoUML和Rose,通常都有根据UML图直接生成代码。
这里介绍一下在Android Studio中安装UML插件,根据代码自动生成UML类图。
第一种是Code Iris。这个可以直接根据你的项目生成UML类图。
- 在file --> settings --> plugins中搜索Code Iris,搜索结果中安装插件,重启AS。
-
在需要生成UML类图的项目的包名或类名上右键选择Create CodeIris Graph。这时候电脑会明显卡顿一下。
-
生成后,在编辑器的右侧,会有CodeIris的标签,点开就可以了。
-
在打开的UML类图窗口中,可以切换不同的视图:module、view、class。鼠标移动到某一个类的时候,就会显示出这个类所有相关的连接线。
第二种是使用PlantUML。这是需要你去编写代码来生成UML图。
- 在file --> settings --> plugins中搜索PlantUML,搜索结果中安装PlantUML插件,重启AS;
- 安装Graphviz。去Graphviz官网下载,然后安装。注意这里有两个下载选项,第一个.msi文件就是需要你自己去安装;另一个压缩文件是绿色版,直接解压就可以用。
-
打开AS的File->Settings->Other Settings ->PlantUML。将将文件路径填写为刚刚Graphviz的目录下bin目录中dot.exe文件。
- 到此,安装工作就结束了。
使用方法,首先要学习一下生成UML的代码,这里提供一个链接,大家可以去学习一下就可以轻松生成UML类图了。PlantUML快速指南