《设计模式详解》

  • 1、设计模式概述
    • 1.1 软件设计模式的产生背景
    • 1.2 软件设计模式的概念
    • 1.3 学习设计模式的必要性
    • 1.4 设计模式分类
  • 2、UML
    • 2.1 类图概述
    • 2.2 类图的作用
    • 2.3 类图表示法
      • 2.3.1 类的表示方式
      • 2.3.2 类与类的关系
        • 2.3.2.1 关联关系
        • 2.3.2.2 聚合关系
        • 2.3.2.3 组合关系
        • 2.3.2.4 依赖关系
        • 2.3.2.5 继承关系
        • 2.3.2.6 实现关系

完整的笔记目录:《设计模式详解》笔记目录,欢迎指点!

学习大纲:

1、设计模式概述

1.1 软件设计模式的产生背景

“设计模式” 最初并不是出现在软件设计中,而是被用于建筑领域的设计中。

1977年美国著名建筑大师、加利福尼亚大学伯克利分校环境结构中心主任克里斯托夫·亚历山大(Christopher Alexander)在他的著作《建筑模式语言:城镇、建筑、构造》中描述了一些常见的建筑设计问题,并提出了 253 种关于对城镇、邻里、住宅、花园和房间等进行设计的基本模式。

1990年软件工程界开始研讨设计模式的话题,后来召开了多次关于设计模式的研讨会。直到1995 年,艾瑞克·伽马(ErichGamma)、理査德·海尔姆(Richard Helm)、拉尔夫·约翰森(Ralph Johnson)、约翰·威利斯迪斯(John Vlissides)等 4 位作者合作出版了 《设计模式:可复用面向对象软件的基础》 一书,在此书中收录了 23 个设计模式,这是设计模式领域里程碑的事件,导致了软件设计模式的突破。这 4 位作者在软件开发领域里也以他们的 “四人组” (Gang of Four,GoF) 著称。

1.2 软件设计模式的概念

软件设计模式(Software Design Pattern),又称设计模式,是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。它描述了在软件设计过程中的一些不断重复发生的问题,以及该问题的解决方案。也就是说,它是解决特定问题的一系列套路,是前辈们的代码设计经验的总结,具有一定的普遍性,可以反复使用。

1.3 学习设计模式的必要性

设计模式的本质是面向对象设计原则的实际运用,是对类的封装性、继承性和多态性以及类的关联关系和组合关系的充分理解。

正确使用设计模式具有以下优点:

  • 可以提高程序员的思维能力、编程能力和设计能力。
  • 使程序设计更加标准化、代码编制更加工程化,使软件开发效率大大提高,从而缩短软件的开发周期。
  • 使设计的代码可重用性高、可读性强、可靠性高、灵活性好、可维护性强。

1.4 设计模式分类

创建型模式:用于描述“怎样创建对象”,它的主要特点是“将对象的创建与使用分离”。

  • GoF 书中提供了:单例、原型、工厂方法、抽象工厂、建造者 5 种创建型模式。

结构型模式:用于描述如何将类或对象按某种布局组成更大的结构。

  • GoF 书中提供了:代理、适配器、桥接、装饰、外观、享元、组合 7 种结构型模式。

行为型模式:用于描述类或对象之间怎样相互协作共同完成单个对象无法单独完成的任务,以及怎样分配职责。

  • GoF 书中提供了:模板方法、策略、命令、职责链、状态、观察者、中介者、迭代器、访问者、备忘录、解释器 11 种行为型模式。

2、UML

统一建模语言 (Unified Modeling Language,UML) 是用来设计软件的可视化建模语言。它的特点是简单、统一、图形化、能表达软件设计中的动态与静态信息。

UML 从目标系统的不同角度出发,定义了:用例图、类图、对象图、状态图、活动图、时序图、协作图、构件图、部署图 9 种图。

2.1 类图概述

类图(Class diagram)是显示了模型的静态结构,特别是模型中存在的类、类的内部结构以及它们与其他类的关系等。类图不显示暂时性的信息。类图是面向对象建模的主要组成部分。

2.2 类图的作用

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

2.3 类图表示法

2.3.1 类的表示方式

在 UML 类图中,类使用包含类名、属性(field)和方法(method)且带有分割线的矩形来表示。

比如下图表示一个 Employee 类,它包含 name、age 和 address 这 3 个属性,以及 work() 方法:

属性/方法名称前的 +- 表示了这个属性/方法的可见性,UML 类图中表示可见性的符号有三种:

  • +:表示 public

  • -:表示 private

  • #:表示 protected

属性的完整表示方式是: 可见性 名称 :类型 [ = 缺省值]

方法的完整表示方式是: 可见性 名称(参数列表) [ : 返回类型]

注意:

​ 1,中括号中的内容表示是可选的

​ 2,也有将类型放在变量名前面,返回值类型放在方法名前面

示例:

上图 Demo 类定义了三个方法:

  • method() 方法:修饰符为 public,没有参数,没有返回值。
  • method1() 方法:修饰符为 private,没有参数,返回值类型为 String。
  • method2() 方法:修饰符为 protected,接收两个参数,第一个参数类型为 int,第二个参数类型为 String,返回值类型是 int。

2.3.2 类与类的关系

2.3.2.1 关联关系

关联关系是对象之间的一种引用关系,用于表示一类对象与另一类对象之间的联系,如老师和学生、师傅和徒弟、丈夫和妻子等。

关联关系是类与类之间最常用的一种关系,分为一般关联关系、聚合关系和组合关系。

一般关联又可以分为:单向关联,双向关联,自关联。

1,单向关联

在 UML 类图中,单向关联用一个带箭头的实线表示。

上图表示每个顾客都有一个地址,通过让 Customer 类持有一个类型为 Address 的成员变量类实现。

2,双向关联

从上图中我们很容易看出,所谓的双向关联就是双方各自持有对方类型的成员变量。

在 UML 类图中,双向关联用一个不带箭头的直线表示。

上图中在 Customer 类中维护一个 List<Product>,表示一个顾客可以购买多个商品;

在 Product 类中维护一个 Customer 类型的成员变量,表示这个产品被哪个顾客所购买。

3,自关联

在 UML 类图中,自关联用一个带有箭头且指向自身的线表示,

上图表示 Node 类包含类型为 Node 的成员变量,也就是 “自己包含自己”。

2.3.2.2 聚合关系

聚合关系是关联关系的一种,是强关联关系,是整体和部分之间的关系。

聚合关系也是通过成员对象来实现的,其中成员对象是整体对象的一部分,但是成员对象可以脱离整体对象而独立存在。

例如,学校与老师的关系,学校包含老师,但如果学校停办了,老师依然存在。下图所示是大学和教师的关系图:

在 UML 类图中,聚合关系可以用带空心菱形的实线来表示,菱形指向整体。

2.3.2.3 组合关系

组合表示类之间的整体与部分的关系,但它是一种更强烈的聚合关系。

在组合关系中,整体对象可以控制部分对象的生命周期,一旦整体对象不存在,部分对象也将不存在,部分对象不能脱离整体对象而存在。

例如,头和嘴的关系,没有了头,嘴也就不存在了。下图所示是头和嘴的关系图:

在 UML 类图中,组合关系用带实心菱形的实线来表示,菱形指向整体。

注意区分聚合关系与组合关系,它们的主要区别就是:部分能否脱离整体而存在

2.3.2.4 依赖关系

依赖关系是平时用的最多的一种关系,耦合性较弱

依赖关系是一种使用关系,它是对象之间耦合度最弱的一种关联方式,是临时性的关联。

在代码中,某个类的方法通过局部变量、方法的参数或者对静态方法的调用来访问另一个类(被依赖类)中的某些方法来完成一些职责。

下图所示是司机和汽车的关系图,司机驾驶汽车:

在 UML 类图中,依赖关系使用带箭头的虚线来表示,箭头从使用类指向被依赖的类。

2.3.2.5 继承关系

继承关系,也称为泛化关系,耦合性很强(某个类发生变化,其他类也得变)

继承关系是对象之间耦合度最大的一种关系,表示一般与特殊的关系,是父类与子类之间的关系。

在代码实现时,使用面向对象的继承机制来实现泛化关系。

例如,Student 类和 Teacher 类都是 Person 类的子类,其类图如下图所示:

在 UML 类图中,泛化关系用带空心三角箭头的实线来表示,箭头从子类指向父类。

2.3.2.6 实现关系

实现关系是接口与实现类之间的关系。

在这种关系中,类实现了接口,类中的操作实现了接口中所声明的所有的抽象操作。

例如,汽车和船实现了交通工具,其类图如下图所示:

在 UML 类图中,实现关系使用带空心三角箭头的虚线来表示,箭头从实现类指向接口。

《设计模式详解》设计模式概述、UML相关推荐

  1. 设计模式学习,23种设计模式详解:概述

    设计模式学习:概述 首先,别把程序设计不当设计! 程序的框架就是建筑物的骨架,内部实现不过是装修改造.只要骨架设计没有问题,装修起来也是得心应手.一个糟糕的程序框架,对于接下来的Debug和程序的更新 ...

  2. 《设计模式详解》笔记目录

    <设计模式详解> 前言 后记 目录 设计模式概述.UML 软件设计原则 创建型模式 单例模式 工厂模式 原型模式 建造者模式 结构型模式 代理模式 适配器模式 装饰者模式 桥接模式 外观模 ...

  3. 《设计模式详解》手写简单的 Spring 框架

    自定义 Spring 框架 自定义 Spring 框架 Spring 使用回顾 Spring 核心功能结构 bean 概述 Spring IOC 相关接口 BeanFactory 接口 BeanDef ...

  4. 《设计模式详解》行为型模式 - 解释器模式

    解释器模式 6.11 解释器模式 6.11.1 概述 6.11.2 结构 6.11.3 案例实现 6.11.4 优缺点 6.11.5 使用场景 完整的笔记目录:<设计模式详解>笔记目录,欢 ...

  5. 《设计模式详解》行为型模式 - 备忘录模式

    备忘录模式 6.10 备忘录模式 6.10.1 概述 6.10.2 结构 6.10.3 案例实现 "白箱" 备忘录模式 "黑箱" 备忘录模式 6.10.4 优缺 ...

  6. 《设计模式详解》行为型模式 - 中介者模式

    中介者模式 6.7 中介者模式 6.7.1 概述 6.7.2 结构 6.7.3 案例实现 6.7.4 优缺点 6.7.5 使用场景 完整的笔记目录:<设计模式详解>笔记目录,欢迎指点! 6 ...

  7. 《设计模式详解》行为型模式 - 观察者模式

    观察者模式 6.6 观察者模式 6.6.1 概述 6.6.2 结构 6.6.3 案例实现 6.6.4 优缺点 6.6.5 使用场景 6.6.6 JDK 提供的实现 - Observable 示例 完整 ...

  8. 《设计模式详解》行为型模式 - 职责链模式

    职责链模式 6.4 职责链模式 6.4.1 概述 6.4.2 结构 6.4.3 案例实现 6.4.4 优缺点 6.4.5 JavaWeb 源码 - FilterChain 完整的笔记目录:<设计 ...

  9. 《设计模式详解》行为型模式 - 命令模式

    命令模式 6.3 命令模式 6.3.1 概述 6.3.2 结构 6.3.3 案例实现 6.3.4 优缺点 6.3.5 使用场景 6.3.6 JDK 源码 - Runnable 完整的笔记目录:< ...

最新文章

  1. 从BloomFilter到Counter BloomFilter
  2. 【引用】Android程序实现完全退出
  3. 日子是过以后、不是过从前
  4. 4、使用PreparedStatement接口实现增,删,改操作(常用)
  5. java只有高跟很高_女明星们为了合影不输,练就踩高跷本领,鞋跟一个比一个高!...
  6. int最大值java_Java 中一个int型数组的求最大值最小值 | 学步园
  7. 卧槽!我的IDEA中XML显示屎黄色,怎么去掉?
  8. idea配置mysql失败_IDEA配置数据库连接失败的问题
  9. 京东金融移动安全体系
  10. mybatis update不生效_08. mybatis一级缓存和二级缓存
  11. Java 员工信息管理系统
  12. 安卓仿苹果键盘输入法_仿ios输入法安卓版
  13. 柯尼卡美能达c353改语言,柯尼卡美能达bizhub c353c253c203维修手册中文部分2.pdf
  14. python爬虫爬取网站视频
  15. Windows 搭建Syslog、RSyslog日志服务器
  16. 怎样写一篇critical review
  17. matlab--积分计算
  18. HyperLynx 仿真
  19. 目标检测网络---评价指标
  20. 2023小红书年度生活趋势报告

热门文章

  1. 企业要做有价值的私域流量三大关键
  2. 苹果手机的隔空投送怎么使用?
  3. TCP/IP之路由算法
  4. Linux各个文件夹介绍
  5. SpringMVC_02
  6. codeblock无法新建工程_龙园路顶管工程顶管机顺利始发,项目预计明年5月完工...
  7. cte公用表表达式_SQL Server公用表表达式(CTE)
  8. sql 如何设置行级锁_如何使用SQL Server 2016行级安全性过滤和阻止数据访问
  9. SQL Server中的内存优化表变量
  10. 树和二叉树2——输出广义表形式(带括号)二叉树