万丈高楼平地起:UML类图

UML类图

UML类图 是一种静态的结构图,描述了系统的类的集合,类的属性和类之间的关系,可以简化了人们对系统的理解。UML类图 是系统分析和设计阶段的重要产物,是系统编码和测试的重要模型。

图示

解析

圆角矩形框,它就代表一个类(Class)

类图分为三层:

  • 第一层显示类的名称,如果是抽象类,则就用斜体显示
  • 第二层是类的特性,通常就是字段和属性
  • 第三层是类的操作,通常是方法或行为。
    • 注意前面的符号:
      • '+':表示public
      • '-' :表示private
      • '#':表示protected

接口

解析

矩形框,顶端有<<interface>>显示,第一行是接口名称,第二行是接口方法。

**注意:**接口还有另一种表示方法,俗称棒棒糖表示法。比如下图中的唐老鸭类就是实现了 "讲人话"的接口。

UML关系

1. 继承

**描述:**继承关系用 空心三角形+实线 来表示

举例: 面向对象说过,继承是一种 "is a " 的关系,鸟是动物中的一种

2. 实现

**描述:**实现接口用 空心三角形+虚线 来表示

举例: 大雁实现了 飞翔接口,定义大雁飞的方法

3. 关联

**描述:**关联关系用 实线箭头 来表示

举例: 企鹅和气候两个类,企鹅是很特别的鸟,会游不会飞。更重要的是,它与 气候 有很大的关联。我们不去讨论为什么北极没有企鹅,为什么它们要每年长途跋涉。总之,企鹅需要知道 "气候" 的变化,需要了解 "气候" 规律。当一个类 "需要知道" 另一个类时,可以用关联(association)关系表示。

4. 聚合

**描述:**聚合关系用 空心的菱形+实线箭头 来表示

举例: 大雁是群居动物,每只大雁都属于一个雁群, 一个雁群可以有多只大雁。所以它们之间就满足 聚合(Aggregation)关系。聚合表示一种弱的 "拥有" 关系,体现的是A对象可以包含B对象,但B对象不是A对象的一部分。

5. 组合

**描述:**组合关系用 实心的菱形+实线箭头 来表示

**举例:**组合是一种强的 "拥有" 关系,体现了严格的部分和整体的关系,部分和整体的生命周期一样。鸟和其翅膀就是组合(合成)关系,因为它们是部分和整体的关系,并且翅膀和鸟的生命周期是相同的。

另外,你会注意到合成关系的连线两端还有一个数字 '1' 和数字 '2' ,这被称为基数。表明这一端的类可以有几个实例,很显然,一个鸟应该有两只翅膀。如果一个类可能有无数个实例,则就用'n'来表示。关联关系、聚合关系也可以有基数


6. 依赖

**描述:**依赖关系(Dependency),用虚线箭头来表示

举例: 动物要有生命力,需要氧气、水以及食物等依赖