`
javahigh1
  • 浏览: 1276741 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

设计模式区别(一)

 
阅读更多

最近一段时间一直在学习设计模式,我有一个感受就是:接触头几个设计模式时感觉似乎就那么一回事,好像没有什么可学习的,因为理解起来很简单,也很容易记忆,在例子的带动下似乎也有那么一点意思了,好像自己懂了。慢慢地,随着学习的深入,接触到了各种各样的设计模式,前面那种轻松的劲儿就没了,越学越迷糊,感觉很多模式好像都是类似的,自己也分不清和前面学的模式的区别是什么了。再后来,经过对这23种基本的设计模式仔细研究,对比其实现类图以及模式使用的目的,基本上清楚明白了各个设计模式之间的区别以及他们各自的使用范围,为了使和我一样在学习设计模式的朋友少一些迷惑,我将我认为的一些类似的、容易混淆的设计模式之间的区别总结出来共享给大家,希望能有所帮助,如有谬误,欢迎指正。

在进入正题之前,首先来了解一些基本的东西,有助于理解设计模式。

在面向对象编程中,理解对象、接口、类和继承子类的概念对大多数人来说并不困难,问题关键在于如何运用它们写出灵活的、可复用的软件,而设计模式则可以告诉你如何去做。

面向对象系统中功能复用最常用的技术是类继承对象组合。类继承属于白盒复用,也就是说通过生成子类来达到复用的目的,父类的内部细节对子类可见;对象组合属于黑盒复用,对象的内部细节是不可见的,对象组合要求被组合的对象具有良好定义的接口。针对以上的复用技术,我们需要遵守两条原则:第一,针对接口编程,而不是针对实现编程;第二,优先使用对象组合,而不是类继承。

针对接口编程有两个好处:第一个好处是客户不需要知道他们使用的对象的特定类型 ,只须对象有客户所期望的接口;第二个好处是客户无须知道他们使用的对象是用什么类来实现的,他们只须知道定义的接口或者抽象类。这将极大的减少子系统实现之间的相互依赖关系。

优先使用对象组合的优点是:第一,由于对象的实现是基于接口编写的,所以在实现上存在较少的依赖关系,可以在运行时刻动态的替换引用的对象实现;第二,优先使用对象组合有助于保持每个类背封装,并被集中在单个任务上,这样类和类的继承层次会保持在较少的规模,并且不太可能增长为不可控制的庞然大物;第三,使用对象组合可以最大限度的不用创建新的构件,而使用已有的构件就可以组装获得所需要的功能。

设计模式就采用了大量的对象复合技术。设计模式按照目的划分,可以分为创建型、结构型、行为型三种,其中创建型模式与对象的创建有关,结构型模式处理类或对象的组合;行为型模式对类或对象怎样交互和怎样分配职责进行描述。

下面是各种模式按照目的划分的分类

创建型模式:Factory Method、Abstract Factory、Builder、Prototype、 Singleton

构造型模式:Adapter、Bridge、Composite、Decorator、Façade、Flyweight、
Proxy

行为型模式:Chain of Responsibility、Command、Iterator、Mediator、Mementor、Memento、Observer、State、Stategy、Visitor、Template Method、
Interpreter

<shapetype id="_x0000_t75" coordsize="21600,21600" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75"><font size="3"><font face="宋体"> <stroke joinstyle="miter"></stroke></font></font><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock><shape id="_x0000_s1044" style="MARGIN-TOP: 69.05pt; Z-INDEX: 1; LEFT: 0px; MARGIN-LEFT: 94.5pt; WIDTH: 417pt; POSITION: absolute; HEIGHT: 267pt; TEXT-ALIGN: left; mso-position-horizontal-relative: text; mso-position-vertical-relative: text; mso-position-horizontal: absolute; mso-position-vertical: absolute" type="#_x0000_t75"><imagedata o:title="" src="file:///C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/msohtml1/01/clip_image001.png"></imagedata><wrap type="square"></wrap></shape><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock></shapetype><shape id="_x0000_i1025" style="WIDTH: 417pt; HEIGHT: 267pt" type="#_x0000_t75"><imagedata o:title="" src="file:///C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/msohtml1/01/clip_image001.png"></imagedata></shape>

<shapetype id="_x0000_t75" coordsize="21600,21600" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75"><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock></shapetype><shape id="_x0000_i1025" style="WIDTH: 417pt; HEIGHT: 267pt" type="#_x0000_t75"><imagedata o:title="" src="file:///C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/msohtml1/01/clip_image001.png"></imagedata></shape>

创建型模式之间的区别

GoF23种设计模式中创建型模式有5种,分别是:Singleton单件模式、Abstract Factory抽象工厂模式、Builder生成器模式、Factory Method工厂方法模式、Prototype原形模式。由于创建型模式与对象创建有关,所以这几种模式一般不会与其他的结构型模式和行为型模式混淆,这里将创建型模式单独列出来集中讲解。下面分别总结这几种设计模式。

设计模式

GoF的描述

优点或缺点

Singleton单件模式

保证一个类仅有一个实例,并提供一个该实例全局的访问点

可以保证唯一实例;允许在需要时拥有可变数目的实例

Abstract Factory抽象工厂模式

提供一个接口,让该接口负责创建一系列相关或者相互依赖的对象,无需指定他们的具体类

分离了具体的类;可以生产一系列的相关对象,有利于产品的一致性;缺点是难以支持新种类的产品

Builder生成器模式

将一个复杂对象的构建与其表示向分离,使得同样的构建过程可以创建不同的表示

可以使你改变一个产品的内部表示;将构造过程和表示分开;可以对构造过程进行更精细的控制

Factory Method工厂方法模式

定义一个用于创建对象的接口,让子类决定实例化那个类。FactoryMethod使得一个类的实例化延迟到子类

为子类提供了挂钩以提供对象的扩展版本,也就是说子类可以覆盖工厂方法改变创造的产品实例

Prototype原形模式

使用原型实例指定创建对象的种类,然后通过拷贝这些原型来创建新的对象

改变值获得新的对象;可以在运行时刻指定要实例化的类,例如某个对象设置了若干属性之后,我们需要N这种设置了相同属性的对象,那么可以通过该模式,在动态运行时直接拷贝来生成

这里容易混淆的是Abstract Factory模式和Builder模式,Factory Method模式和Prototype模式也不好区分。Singleton模式没什么太大的困难。下面就来分析一下前四种模式。

一、Abstract Factory模式和Builder模式:

Abstract Factory是应对一系列对象的创建的问题,对于创建一个汽车对象来说,Abstract Factory模式更关注一系列的对象的创建,如:WheelEngineBody等等类型的创建, 这里的一系列可以这样理解,宝马汽车需要宝马的Wheel,宝马的Engine,宝马的Body等等一系列配套的东西,而保时捷汽车则需要保时捷的Wheel,保时捷的Engine等等和保时捷配套的东西。大家注意这换句话说关注点在这一系列对象上,同时它关注创建对象得到的结果

Builder则是将复杂对象的构建过程与它的表示相分离,使得不同的表示可以使用同样的构建过程。这里我们要注意红色的部分,即构建过程与表示相分离,我们可以如此理解,也就是说将结果与对象创建过程进行分离,这里关注点是过程。Builder模式注重的对象生产的过程,也就是如何一步一步将需要的对象构建起来的,同样对于一个汽车对象来举例,我们需要首先创建Wheel,再创建Engine,再创建Body,然后将他们进行组装,得到想要的汽车对象,可以看到,Builder模式将构建的组装的过程进行了隐藏和封装。而Abstract Factory则只是一系列对象的工厂,组装可能还是需要客户自己来完成。

二、Factory Method模式和Prototype模式:

这两个模式区别比较简单,可以这样理解,Factory Method模式是重新创建一个对象;Prototype模式是利用现有的对象进行克隆,当两个对象或多个对象雷同的时候,可以考虑用一个已创建的对象去克隆出其余的对象。

Abstract Factory一般是利用Factory Method模式来完成一系列对象中的单个对象的创建。

未完待续

分享到:
评论

相关推荐

    设计模式的杰作:深入设计模式

    《深入设计模式》是一部由亚历山大·什韦茨所著、彭力翻译的作品,旨在通过深入浅出的方式介绍设计模式的相关内容。该书不仅包含了面向对象程序设计的基础知识,还详细探讨了设计模式的概念及其应用价值,同时介绍了...

    23种设计模式详细介绍与区别

    设计模式是软件工程中的一种最佳实践,用于解决常见的设计问题并促进代码的可维护性和复用性。在本文中,我们将深入探讨标题提及的23种设计模式,并着重讨论桥接模式与适配器模式、装饰模式与代理模式、状态模式与...

    六种微服务架构的设计模式.pdf

    微服务架构的设计模式是软件架构中的一种重要设计模式,它可以帮助开发者设计和实现更加灵活、可扩展和高效的微服务系统。在这篇文章中,我们将探讨六种常见的微服务架构设计模式:聚合器微服务设计模式、代理微服务...

    JavaScript设计模式与开发实践.pdf

    第一部分讲解了JavaScript语言的面向对象和函数式编程的知识,包括静态类型语言和动态类型语言的区别及其在实现设计模式时的异同、封装、继承、多态在动态类型语言中的体现、JavaScript基于原型继承的面向对象系统的...

    设计模式解析

    本资料"设计模式解析(第二版)"正是这样一本专注于此主题的资源。 设计模式通常分为三类:创建型模式、结构型模式和行为型模式。创建型模式关注对象的创建过程,如单例模式、工厂模式和建造者模式等,它们帮助我们...

    设计模式精解 设计模式精解

    根据给定的信息,本文将深入探讨GoF23种设计模式的核心概念及其应用场景,并通过具体的实例来解析每一种设计模式的实现原理和技术要点。 ### 0. 引言 设计模式是一系列被广泛接受的解决方案,用于解决软件设计中...

    java 设计模式试题

    题目中的第一个选项“同一问题的不同表现形式”(A) 描述了设计模式的主要应用场景之一。设计模式帮助开发者处理常见的软件设计难题,确保代码的可读性、可维护性和可扩展性。 ### 2. 面向对象的基本原则 面向对象...

    《java设计模式》课后习题模拟试题解答——刘伟.zip

    3. **模式间的相互关系**:了解不同设计模式之间的关联和区别,比如装饰器和代理模式的区别,或者单例模式与静态内部类的实现差异。 4. **模式的优缺点**:评估每种模式的适用性和潜在问题,如过度设计或性能影响。 ...

    小D深入浅出设计模式+框架源码剖析实战

    ├─第一章 旭瑶-小滴架构师成长系列软件设计模式课程介绍 │ 1.2设计模式全家桶课程大纲速览.mp4 │  ├─第二章 想成为架构师的你,不可不知道的设计模式精髓 │ 2.1设计模式的六大原则你知道多少.mp4 │ 2.3...

    设计模式实训教程代码

    第三部分对各种相关联的设计模式进行了深入分析和比较,旨在阐明各种设计模式比较理想的应用场景和它们之间的区别;第四部分探讨了设计模式的混编,讲解了如何在实际开发中将各种设计模式混合起来使用,以发挥设计...

    软件设计模式实验

    一、创建型设计模式实验 在软件设计中,创建型设计模式是指用来创建对象的模式。常见的创建型设计模式有六种,即简单工厂模式、工厂方法模式、抽象工厂模式、建造者模式、原型模式和单例模式。通过使用Visio或Rose...

    二十三种设计模式【PDF版】

    GoF 的设计模式表面上好象也是一种具体的"技术",而且新的设计模式不断在出现,设计模式自有其自己的发展轨道,而这 些好象和 J2EE .Net 等技术也无关! 实际上,GoF 的设计模式并不是一种具体"技术",它讲述的是...

    php设计模式高清版

    #### 四、设计模式与代码库的区别 设计模式与代码库有着本质的不同。代码库是一组预先编写好的代码,可以直接在项目中使用。而设计模式则是一种指导思想,告诉开发者如何组织和构建代码。设计模式更像是制作衬衫的...

    软件设计模式与体系结构练习题

    设计模式是一种在特定情况下解决常见问题的标准化解决方案,而体系结构则是软件系统的整体构造和组织方式。这篇练习题的资源旨在帮助学习者深化对这些概念的理解。 1. **设计模式**: - **单例模式**:确保一个类...

    Head.First.设计模式中文版pdf(第二部分/共七部分)

    《Head First 设计模式》中的另一个亮点是将设计模式拟人化,通过模式告白节目这一独特形式,以对话的形式深入探讨设计模式的内部机制和应用。这种方法不仅减少了学习的枯燥感,也让复杂的概念变得易于理解。 本书...

    时间触发嵌入式系统设计模式_时间触发嵌入式系统设计模式_嵌入式_

    时间触发嵌入式系统设计模式是嵌入式系统开发中的一种重要方法,它强调了系统的时序性和可预测性,确保在预定义的时间间隔内执行特定任务,从而提高系统的可靠性和稳定性。这种设计模式通常应用于实时性和安全性要求...

    Head first 设计模式 第一章 策略模式 pdf + 源代码

    《Head First设计模式》是软件开发领域中一本非常经典的书籍,尤其对于初学者而言,它以生动、直观的方式讲解了设计模式的精髓。第一章重点介绍了策略模式,这是一种行为设计模式,它使你能在运行时改变对象的行为。...

    设计模式面试题

    #### 一、设计模式概览及常见设计模式解析 在软件工程领域,设计模式是一套被广泛接受的解决特定问题的解决方案模板。设计模式可以分为三大类:创建型模式、结构型模式和行为型模式。 **1. 常见的设计模式有哪些?...

    android 24种设计模式介绍与6大设计原则

    在Android开发中,设计模式和设计原则是提升代码质量、可维护性和可扩展性的重要工具。以下是关于"Android 24种设计模式介绍与6大设计原则"的详细阐述: 一、六大设计原则 1. **单一职责原则(Single ...

    java设计模式高清教程

    Java设计模式是软件开发中的重要概念,它是一种在特定情境下解决问题的经验总结,可以提高代码的可重用性、灵活性和可维护性。本高清教程深入浅出地讲解了Java中的各种设计模式,对于提升开发者的技术能力和面试表现...

Global site tag (gtag.js) - Google Analytics