写点什么

第 3 周总结 - 代码重构 - 使用 UML 类图表达程序逻辑

用户头像
潘涛
关注
发布于: 2021 年 01 月 17 日

通常类与类之间,存在继承、依赖、实现、组合、聚合、关联关系;

类的内部有类名、方法、属性;

方法/属性有 private protect defalut public 的范围,也有 String Boolean 等类型,方法还有入参、出参等;


如何使用通过 UML 来表示这些内容,表达程序的逻辑?


一、类与类之间的关系

1、继承关系 

继承指的是一个类继承另外一个类的关系(子类与父类,子类与基类等),并可以在子类中增加它自己的新功能的能力。在 UML 类图设计中,继承用一条带空心三角箭头的实线表示,从子类指向父类,或者子接口指向父接口。 


2、实现关系     

实现指的是一个 class 类实现 interface 接口(可以是多个)的关系。在 UML 类图设计中,实现用一条带空心三角箭头的虚线表示,从类指向实现的接口。 



3、依赖关系     

依赖就是一个类 A 使用到了另一个类 B,而这种使用关系是具有偶然性的、临时性的、非常弱的,但是类 B 的变化会影响到类 A。比如某人要过河,需要借用一条船,此时人与船之间的关系就是依赖。表现在代码层面,为类 B 作为参数被类 A 在某个 method 方法中使用。在 UML 类图设计中,依赖关系用由类 A 指向类 B 的带箭头虚线表示。 


4、关联关系  

关联体现的是两个类之间语义级别的一种强依赖关系,比如我和我的朋友,这种关系比依赖更强、不存在依赖关系的偶然性、关系也不是临时性的,一般是长期性的,而且双方的关系一般是平等的。关联可以是单向、双向的。表现在代码层面,为被关联类 B 以类的属性形式出现在关联类 A 中,也可能是关联类 A 引用了一个类型为被关联类 B 的全局变量。在 UML 类图设计中,关联关系用由关联类 A 指向被关联类 B 的带箭头实线表示,在关联的两端可以标注关联双方的角色和多重性标记。 


5、聚合关系     

聚合是关联关系的一种特例,它体现的是整体与部分的关系,即 has-a 的关系。此时整体与部分之间是可分离的,它们可以具有各自的生命周期,部分可以属于多个整体对象,也可以为多个整体对象共享。比如计算机与 CPU、公司与员工的关系等,比如一个航母编队包括海空母舰、驱护舰艇、舰载飞机及核动力攻击潜艇等。表现在代码层面,和关联关系是一致的,只能从语义级别来区分。在 UML 类图设计中,聚合关系以空心菱形加实线箭头表示。 


6、组合关系    

组合也是关联关系的一种特例,它体现的是一种 contains-a 的关系,这种关系比聚合更强,也称为强聚合。它同样体现整体与部分间的关系,但此时整体与部分是不可分的,整体的生命周期结束也就意味着部分的生命周期结束,比如人和人的大脑。表现在代码层面,和关联关系是一致的,只能从语义级别来区分。在 UML 类图设计中,组合关系以实心菱形加实线箭头表示。 


二、类的属性的表示方式

在 UML 类图中,类使用包含类名、属性(field) 和方法(method) 且带有分割线的矩形来表示,比如下图表示一个 Employee 类,它包含 name,age 和 email 这 3 个属性,以及 modifyInfo()方法。


那么属性/方法名称前加的加号和减号是什么意思呢?

它们表示了这个属性或方法的可见性,UML 类图中表示可见性的符号有三种:

1. + :表示 public

2. - :表示 private

3. #:表示 protected(friendly 也归入这类)

因此,上图中的 Employee 类具有 3 个私有属性和一个公有方法。


三、使用 Visio 完成一个完整类图

Visio 提供对 UML 的支持,可以使用它来完成类图的表示,如下是 Visio 提供的组件,清晰明了:


以下类图,是使用组合模式的一个表示:

Component 抽象类,定义了所有组件的方法:add/display

Frame 类与抽象类 Component 是组合关系

Label/Button/TextBox 等实现 Component 抽象类

WindowsClient 类是程序入口。



用户头像

潘涛

关注

还未添加个人签名 2020.02.25 加入

还未添加个人简介

评论

发布
暂无评论
第3周总结-代码重构-使用UML类图表达程序逻辑