目录

  • 设计模式是什么?
    • 设计模式包含哪些内容?
  • 设计模式的历史
  • 为什么以及如何学习设计模式?
  • 关于模式的争议
    • 一种针对不完善编程语言的蹩脚解决方案
    • 低效的解决方案
    • 不当使用
  • 设计模式的分类

设计模式是什么?

设计模式是软件设计中常见问题的解决方案。他们可以根据需求调整自己的预制蓝图,可以解决代码中反复出现过的设计问题。
设计模式与方法或库的使用方式不同,很难直接套用在自己的程序中。模式并不是指一段特定的代码,而是解决问题的一般性概念。你可以根据设计模式来实现符合自己程序实际所需的解决方案。
大多数人会分不清出模式和算法,因为两者在概念上都是已知特定问题的典型解决方案。但是算法总是明确定义达成特定目标所需的一系列步骤,而步骤则是对解决问题的更高层次描述。同一个设计模式在两个不同的程序中实现的代码可能会不一样。
算法更像是菜谱,教你一步一步的达成目标。而设计模式更像是蓝图,你可以看到最终的结果和模式的功能,但是需要自己确定实现步骤。

设计模式包含哪些内容?

大部分设计模式都有正规的描述方式,以便在不同情况下使用。模式的描述通常会包括一下部分:

  • 意图:简单描述问题和解决方案
  • 动机:进一步解释问题并说明模式会如何提供解决方案
  • 结构:展示模式之间的每个部分和它们之间的关系
  • 在不同的语言中的实现提供流行编程语言的代码,让读者更好地理解设计模式背后的思想。

设计模式的历史

谁发明了设计模式? 这是一个很好的问题, 但也有点不太准确。 设计模式并不是晦涩的、 复杂的概念——事实恰恰相反。 模式是面向对象设计中常见问题的典型解决方案。 同样的解决方案在各种项目中得到了反复使用, 所以最终有人给它们起了名字, 并对其进行了详细描述。 这基本上就是模式被发现的历程了。

模式的概念是由克里斯托佛·亚历山大在其著作 《建筑模式语言》 中首次提出的。 本书介绍了城市设计的 “语言”, 而此类 “语言” 的基本单元就是模式。 模式中可能会包含对窗户应该在多高、 一座建筑应该有多少层以及一片街区应该有多大面积的植被等信息的描述。

埃里希·伽玛、 约翰·弗利赛德斯、 拉尔夫·约翰逊和理查德·赫尔姆这四位作者接受了模式的概念。 1994 年, 他们出版了 《设计模式: 可复用面向对象软件的基础》 一书, 将设计模式的概念应用到程序开发领域中。 该书提供了 23 个模式来解决面向对象程序设计中的各种问题, 很快便成为了畅销书。 由于书名太长, 人们将其简称为 “四人组 (Gang of Four, GoF) 的书”, 并且很快进一步简化为 “GoF 的书”。

此后, 人们又发现了几十种面向对象的模式。 ​ “模式方法” 开始在其他程序开发领域中流行起来。 如今, 在面向对象设计领域之外, 人们也提出了许多其他的模式。


为什么以及如何学习设计模式?

或许你已经从事程序开发工作多年,但是完全不知道单例模式是什么。很多人都是这样。即便如此,你可能会在自己不知情的情况下已经使用过一些设计模式了。所以我们为什么不花一些时间来进一步学习设计模式呢?

  • 设计模式是针对软件设计中常见问题的工具箱, 其中的工具就是各种经过实践验证的解决方案。 即使你从未遇到过这些问题, 了解模式仍然非常有用, 因为它能指导你如何使用面向对象的设计原则来解决各种问题。
  • 设计模式定义了一种让你和团队成员能够更高效沟通的通用语言。 你只需说 “哦, 这里用单例就可以了”, 所有人都会理解这条建议背后的想法。 只要知晓模式及其名称, 你就无需解释什么是单例。

关于模式的争议

设计模式自其诞生之初似乎就饱受争议, 所以让我们来看看针对模式的最常见批评吧。

一种针对不完善编程语言的蹩脚解决方案

通常当所选编程语言或技术缺少必要的抽象功能时, 人们才需要设计模式。 在这种情况下, 模式是一种可为语言提供更优功能的蹩脚解决方案。

例如, 策略模式在绝大部分现代编程语言中可以简单地使用匿名 (lambda) 函数来实现。

低效的解决方案

模式试图将已经广泛使用的方式系统化。 许多人会将这样的统一化认为是某种教条, 他们会 “全心全意” 地实施这样的模式, 而不会根据项目的实际情况对其进行调整。

不当使用

这个问题常常会给初学模式的人们带来困扰: 在学习了某个模式后, 他们会在所有地方使用该模式, 即便是在较为简单的代码也能胜任的地方也是如此。


设计模式的分类

不同设计模式的复杂程度、 细节层次以及在整个系统中的应用范围等方面各不相同。 我喜欢将其类比于道路的建造: 如果你希望让十字路口更加安全, 那么可以安装一些交通信号灯, 或者修建包含行人地下通道在内的多层互通式立交桥。

最基础的、 底层的模式通常被称为惯用技巧。 这类模式一般只能在一种编程语言中使用。

最通用的、 高层的模式是构架模式。 开发者可以在任何编程语言中使用这类模式。 与其他模式不同, 它们可用于整个应用程序的架构设计。

此外, 所有模式可以根据其意图或目的来分类。这里推荐三种主要的模式类别:

  • 创建型模式提供创建对象的机制, 增加已有代码的灵活性和可复用性
  • 结构型模式介绍如何将对象和类组装成较大的结构, 并同时保持结构的灵活和高效
  • 行为模式负责对象间的高效沟通和职责委派

设计模式的介绍。(可能工作了多年才发现设计模式的重要性)相关推荐

  1. 【设计模式】谈谈我们工作中的23个设计模式

    ID 标题 地址 1 设计模式面试题(总结最全面的面试题) https://writer.blog.csdn.net/article/details/127910080 2 Java基础知识面试题(总 ...

  2. 工作多年才发现第一学历真的有用,好学校和差学校出来的人就是不一样!

    学历到底有没有用? 一位网友分享了自己的观点: 以前觉得学历没用,工作了就不该看学历,学历不好也有很多大牛.但工作多年,带的人多了,逐渐发现学历,特别是第一学历真的很有用. 很多学校不好的人面试时夸夸 ...

  3. 今天突然看到一篇介绍WIN98的文章,才发现原来真的老了

    从DOS开始接触电脑,再到95 98 SE ME

  4. 签了工作之后才发现,自己太草率了.....我看过的关于职业规划最好最全面的一篇文章...

    在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业生,因为不懂得去规划自己的职业,在工作多年后,依然拿着微薄的薪水 ...

  5. [转]签了工作之后才发现,自己太草率了!(很长很真实!但会对你有所帮助的!)

    在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业生,因为不懂得去规划自己的职业,在工作多年后,依然拿着微薄的薪水 ...

  6. 签了工作之后才发现,自己太草率了.....我看过的关于职业规划最好最全面的一篇文章

    目录(?)[+] 在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业生,因为不懂得去规划自己的职业,在工作多年后, ...

  7. 签了工作之后才发现,自己太草率了.....  很长很真实!但会对你有所帮助的!

    在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业 生,因为不懂得去规划自己的职业,在工作多年后,依然拿着微薄的薪 ...

  8. 签了工作之后才发现,自己太草率了.....我看过的关于职业规划最好最全面的一篇文章 分类: 体会

    在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业生,因为不懂得去规划自己的职业,在工作多年后,依然拿着微薄的薪水 ...

  9. 签了工作之后才发现,自己太草率了(我看过的关于职业规划最好最全面的一篇文章)

    在担任公司高管的几年间,我面试过数以百计的各个层面的员工,其中最让我感到遗憾的一个现象就是很多人有着非常好的素质,甚至有的还是名校的毕业生,因为不懂得去规划自己的职业,在工作多年后,依然拿着微薄的薪水 ...

最新文章

  1. 剑指offer18.删除链表结点(添加dummy,next域结点指向head)
  2. python学习笔记之编写readConfig读写配置文件
  3. php mysql 简单聊天室_聊天室phpmysql(一)
  4. 按钮悬浮固定在微信小程序底部
  5. logstash异常
  6. 这个省3月23日开始错时错峰开学,在校不要求戴口罩!
  7. 【华为云技术分享】解密如何使用昇腾AI计算解决方案构建业务引擎
  8. 优达学城深度学习之五——卷积神经网络
  9. 2019腾讯广告算法初赛第一名的模型
  10. mysql dump xtrabackup_MySQL之备份和恢复(msyqldump、LVM、xtrabackup)
  11. 微信小程序教程笔记7
  12. In file included from /usr/include/stdio.h:27:0, from btest.c:16: /usr/include/feat出错的解决办法
  13. VMware搭建linux集群
  14. 公司中秋趣味比赛二连冠后的思考
  15. python os创建txt文件_Python新建动态命名txt文件
  16. linux systemctl命令详解
  17. OpenResty实现限流的几种方式
  18. ISO 26262 标准小解
  19. 直播系统开发中如何优化API接口的并发
  20. 关于Android Studio 中Android SDK的 SDK Tools 没有CMake下载项问题

热门文章

  1. 计算机手工模拟实验实验报告,计算机模拟手工实验报告标准格式2.doc
  2. 用计算机做出来的歌,电脑里的歌曲太多,教你快速制作歌曲目录
  3. 农村做APP拉新业务,月赚30万,这绝对是20农村最暴利的项目
  4. 区块链技术赋能音乐作品版权保护 法院采信存证证书作为有效权属证据
  5. Responder使用方法
  6. 使用git拉取项目分支操作
  7. Linux wget下载https报错和转义URL报错解决方法
  8. alpha matting
  9. 医院计算机中心主任,秦皇岛妇幼保健院计算机中心主任刘宇:浅谈妇幼专科医院信息化建设...
  10. MYSQL死锁之路 - 常见SQL语句的加锁分析