架构师修炼套路:软件设计模式

1、什么是设计模式(Design Pattern)?

一个设计模式首先描述了一个在我们的环境中不断重复发生的问题,然后描述了解决这个问题的方法的核心。

换句说话,一个设计模式是一个三方规则,描述了一个特定内容、一个问题和一个对应解决方法的关系。

2、为什么要学习设计模式?

设计模式是一种知识和经验,和编程语言无关。熟练的掌握各种设计模式后,程序猿们可以快速识别出一个系统的骨骼框架,也可以快速的搭建出一个健壮高效的系统。

设计模式就像是程序猿们心中的一张张蓝图,握住它们,就可能成为一位有大局观的架构师;松开它们,注定是颗默默无闻的螺丝钉。

3、设计模式的分类

设计模式的分类方式有很多种,目前比较权威的分类方式(《Design Patterns: Elements of Reusable Object-Oriented Software》)是将其分为三类:结构模式(Structural Patterns)、行为模式(Behavioral Patterns)以及创建模式(Creational Patterns)。

结构模式:解耦多个类;引入一个抽象类用于将来的扩展;封装复杂的结构。

行为模式:允许算法和对象职责分配之间的选择(“谁做什么”);简化在运行时难以追踪的复杂的控制流。

创建模式:为复杂的初始化流程提供一个清晰简单的视角;让系统中对象的创建、组合和表达方式与系统本身独立开来。

4、设计模式举例

篇幅所限,所以只选取了两个典型的设计模式来进行讲解,分别为Adapter(Structural Pattern) 和Observer(Behavioral Pattern)。

Adapter

遇到的问题:新的系统需要使用旧的不兼容组件,尽量不修改旧的组件。

目标:提供访问旧组件的入口。

应用场景:假设旧组件LegacyRectangle拥有一个display方法,接收x1、y1、w、h四个参数来展示长方形,但是在新系统中客户期望输入x1、y1、x2、y2四个参数来展示长方形。在客户是上帝的假设下,我们怎样才能既重用旧组件(减少开发新组件的成本)又满足客户的需求呢?

解决方案:在Rectangle(Adapter)中将x1、y1、x2、y2转换成LegacyRectangle所需的x1、y1、w、h,然后调用LegacyRectangle中的display方法。

Observer

遇到的问题:一个对象经常改变它的状态,有多个视图需要展示这个对象的当前状态。

目标:通过定义一个一对多的依赖,使当某一个对象(Publisher)的状态改变时,所有它的依赖者们(Subscriber)都将被通知并且自动更新状态。

应用场景:使用电脑的人都知道,我们可以在很多地方修改同一个文件的名字,比如以下地方(以Mac电脑为例)。

那么大家有没有思考过,当我们在某一个地方修改名字后,操作系统会做什么?所有地方都会立刻更新成修改后的新名字吗?跟我们在哪个地方修改名字会有关系吗?

解决方案:

小 结

生活中模式无处不在,无论你是修桥梁还是种庄稼,代码里面设计模式也无处不在,因为它们都是经过残酷的考验后流传下来的宝贵经验,值得借鉴和学习。

学习设计模式和读书一样,读书是为了培养甚至灌输给我们正确的价值观,但是有很多时候,却是让我们了解,要达到一个所谓正确的价值观,这条道路有多么漫长,多么崎岖。

本文作者:黄文博(点融黑帮),现就职于点融网成都团队移动组,毕业于慕尼黑工业大学,主修计算机科学与技术。曾就职于腾讯北京、西门子慕尼黑总部,并曾两度创业。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,642评论 18 139
  • 🎉 对设计模式的极简说明!🎉 这个话题可以轻易让任何人糊涂。现在我尝试通过用 最简单 的方式说明它们,来让你(和我...
    月球人simon阅读 1,092评论 1 2
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,885评论 25 707
  • 设计模式汇总 一、基础知识 1. 设计模式概述 定义:设计模式(Design Pattern)是一套被反复使用、多...
    MinoyJet阅读 3,922评论 1 15
  • 在日常生活中碰见蜘蛛是一件再平常不过的事情了,但很多人对这种八条腿的生物有一种莫名的恐惧,说实话它们的外貌也确实蛮...
    sofa阅读 613评论 0 0