02.UML类图

1 什么是UML        

        在前言的文章中,简单介绍了设计原则和23中经典设计模式的名称,在正式学习设计原则和设计模式之前,还有一个重要的知识,那就是UML,那么什么是UML呢?我们来看百度百科的介绍:

        UML(Unified Modeling Language)统一建模语言,又称标准建模语言。是用来对软件密集系统进行可视化建模的一种语言。UML的定义包括UML语义和UML表示法两个元素

        UML是在开发阶段,说明、可视化、构建和书写一个面向对象软件密集系统的制品的开放方法。最佳的应用是工程实践,对大规模,复杂系统进行建模方面,特别是在软件架构层次,已经被验证有效。统一建模语言(UML)是一种模型化语言。模型大多以图表的方式表现出来。一份典型的建模图表通常包含几个块或框,连接线和作为模型附加信息之用的文本。这些虽简单却非常重要,在UML规则中相互联系和扩展。

        在本专栏中,我们只了解UML的一个分支——类图即可。

2 UML类图

        Class Diagram:用于表示类、接口、实例等之间相互的静态关系。虽然名字叫类图,但类图中并不只表示类,也可以表示接口。

        类图(ClassDiagram)是用来显示系统中的类、接口、协作以及它们之间的静态结构和关系的一种静态模型。它主要用于描述软件系统的结构化设计,帮助程序员简化对软件系统的理解,它是系统分析与设计阶段的重要产物,也是系统编码与测试的重要模型依据。

        那么我们来看类、抽象类、接口使用UML该如何表示。

2.1 类

        类(Class)是指具有相同属性、方法和关系的对象的抽象,它封装了数据和行为,是面向对象程序设计(OOP)的基础,具有封装性、继承性和多态性等三大特性。在 UML 中,类使用包含类名、属性和操作,用带有分隔线的矩形来表示。

  • 类名(Name):是一个字符串,在UML中通常是粗体,其中抽象类类名用斜体表。
  • 属性(Attribute):是指类的特性,即类的成员变量。例如我们声明一个成员变量 public String name = "tiedan" ,那么public就表示成员变量的可见性,String表示成员变量的类型,name表示成员变量名称,=表示赋值操作,而tiedan表示变量的值,那么在UML中可以采用如下的表示方式:[可见性]属性名:类型[=默认值];注意: "可见性"表示该属性对类外的元素是否可见,包括公有(Public)、私有(Private)、受保护(Protected)和包(package),在类图中分别用符号+、-、#、~表示。
  • 操作(Operations):是类的任意一个实例对象都可以使用的行为,是类的成员方法。在UML中采用如下的表示方式:[可见性]名称(参数列表):[返回类型]。

        注意:对于静态变量或静态方法加下划线。

        类的UML使用用3个矩形拼接表示,最上面的部分标识类的名称,中间的部分标识类的属性,最下面的部分标识类的方法。

2.2 抽象类

        对于抽象类来说,与普通类的唯一区别就是,抽象类名或抽象方法名用斜体表示。

2.3 接口

        接口(Interface)是一种特殊的类,它具有类的结构但不可被实例化,只可以被子类实现。它包含抽象操作,但不包含属性。它描述了类或组件对外可见的动作。

        如果是接口,则需要再接口名上方加 <>。

        我们都知道,接口和类之间有实现关系、类和抽象类之间有继承关系、抽象类和接口之间可以有实现关系,那么它们之间的关系在UML中又如何表示呢?除了继承和实现外,还有没有其它的关系呢?带着这个问题我们来看类、抽象类、接口的UML关系。

2.4 类之间UML关系

        UML 将事物之间的联系归纳为6种,并用对应的图形类表示。根据类与类之间的耦合度从弱到强排列。UML 中的类图有以下几种关系:依赖关系、关联关系、聚合关系、组合关系、泛化(继承)关系和实现关系。其中泛化和实现的耦合度相等,它们是最强的。其关联关系图形表示如下:

        首先我们来看继承与实现关系。

2.4.1 依赖/关联

  • 用空心三角箭头连接两个类;用线条样式区分继承与实现。
  • 实线表示继承。继承只能单一继承。
  • 虚线表示实现。实现可以多实现。

        箭头的方向是从子类指向父类。定义子类需要通过 extends 关键字指定父类。子类一定是知道父类定义的,但父类并不知道子类的定义。只有知道对方信息时才能指向对方。

2.4.2 关联/依赖

  • 用普通箭头连接两个类;用线条样式区分继承与实现。
  • 虚线表示依赖关系:表示一种使用关系,一个类需要借助另一个类来实现功能;一般一个类将另一个类作为参数使用,或作为返回值。
  • 实线表示关联关系:表示一个类对象和另一个类对象有关联;通常一个类中有另一个类对象作为属性。

2.4.3 组合/聚合

  • 用尾部为菱形的线条表示。
  • 聚合:空心菱形,整体和局部的关系,两者有独立的生命周期,是 has-a 的关系。
  • 组合:实心菱形,整体与局部的关系,和聚合关系对比,关系更加强烈,两者具有相同的生命周期。

        常见数字表达及含义,假设有A类和B类,数字标记在A类侧。

  • 0..1:0个或1个实例。
  • 0..*:0个或多个实例。
  • 1..1:1个实例。
  • 1:只能有一个实例。
  • 1..*:至少有一个实例。

        注意:UML 的标准类关系图中,没有实心箭头。有些 Java 编程的 IDE 自带类生成工具可能出现实心箭头,主要目的是降低理解难度。

  • 21
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值