23种设计模式介绍(三)---- 行为型模式

由于设计模式篇幅比较大,如果在一篇文章讲完所有的设计模式的话不利于阅读。于是我把它分为三篇文章

  设计模式都是比较抽象的概念,所以大家一定要确保看懂类图,而后再自己写代码加强记忆。

概述

  行为型模式一共有11种:

  • 模板方法模式(Template Method)
  • 策略模式(Strategy)
  • 命令模式(Command)
  • 中介者模式(Mediator)
  • 观察者模式(Observer)
  • 迭代器模式(Iteratior)
  • 访问者模式(Visiter)
  • 责任链模式(Chain of Responsibility)
  • 备忘录模式(Memento)
  • 状态模式(State)
  • 解释器模式(Interpreter)

  其中有分为:

  算法封装:模板方法、策略、命令模式

  对象去耦:中介、观察者模式

  抽象集合:迭代器模式

  行为扩展:访问者、责任链模式

  对象状态:状态模式

  解释器模式

一、模板方法模式

  定义:定义一个操作中算法的骨架,而将一些步骤延迟到子类中。模板方法使子类可以重定义算法的某些特定步骤而不改变该算法的结构。

  适用:1.需要一次性实现算法的不变部分,并将可变行为留给子类来实现。2子类的共同行为应该被提出来放到公共类中,以避免代买重复。现有代码的差别应该被分离为新的操作。然后用一个调用这些新操作的模板方法来替换这些不同的代码。

  类图:

二、策略模式

  定义:定义一系列算法,把它们一个个封装起来,并且使它们可互相替换。本模式使得算法可独立于使用它的客户而变化。

  角色:策略接口(Strategy)、具体策略、环境对象

  理解:环境对象持有Strategy的引用,Strategy对象可以动态改

  类图:

三、命令模式

  定义:将请求封装成一个对象,从而可用不同的请求对客户端进行参数化,对请求排队或记录请求日志,以及支持可撤销的操作。

  角色:客户端(Client)、命令调用者(Invoker)、命令接口(Command)、具体命令(ConcreteCommand)、命令接收者(Receiver)

  理解:1.invoker保持有command的引用,command保持有Receiver的引用。2.客户创建Receiver、ConcreteCommand并把Receiver设置给ConcreteCommand,客户端直接通过ConcreteCommand.execute执行命令。或者创建一个Invoker并把ConcreteCommand设置给Invoker,然后通过Invoker来调用命令。

  类图:

四、中介者模式

  定义:用中介对象封装一系列的对象交互。中介者使得各对象不需要显示地互相引用,从而使其耦合松散,而且可以独立的改变它们之间的交互。

  角色:中介者接口(Mediator)、具体中介者、同事者接口(Colleague),具体同事者。

  理解:每个Colleague都有一个Mediator实例,Mediator应该知道所有的Colleague

  类图:

五、观察者

  定义:定义了一种一对多的关系,让多个观察者监听某一主题对象,这个主题对象的状态变化时,会通知所有观察者对象,使它们自己更新自己

  角色:发布者接口(Subject)、具体发布者、监听者接口(Observer)、具体监听者。

  理解:Subject提供注册于注销的方法,客户把所有的Observer注册到Subject当中,当需要时Subject遍历所有注册的Observer并通知他们。

  类图:

六、迭代器模式

  定义:提供一种方法顺序的访问一个聚合对象的各个元素,而又不暴露该对象内部表示

  角色:迭代器、集合

  理解:把遍历集合的职能从集合本身转移到迭代器对象,不同的迭代器可以执行不同的遍历策略。

  适用:1.需要访问组合对象的内容,而又不暴露其内部表示。2.需要通过多种方式遍历组合对象3.需要提供一个统一的接口,用来遍历各种类型组合对象。

  类图:

 

七、访问者模式

  定义:表示一个作用于某对象结构中的各元素的操作。它让我们可以在不改变各元素的类的前提下定义作用于这些元素的新操作。

  角色:访问者(Vistor)接口、具体访问者、访问元素(Element)接口、具体元素

  理解:1.元素对象通常是“部分-整体”结构中的节点。2.客户端创建一个ConcreteVistoer,把它传给一个ConcreteElement,ConcreteElement的所有集合都接受ConcreteVistoer的访问。

  适用:

    1. 一个复杂的对象结构包含很多其他对象,它们有不同的接口,但是相对这些对象实施一些依赖于其具体类型的操作。
    2. 需要对一个组合结构中的对象进行很多不相关的操作,但是不想让这些操作污染这些对象的类。可将相关操作集中起来,定义在一个访问者类中,并在需要在访问者中定义的操作时使用它。
    3. 定义复杂的结构类很少作修改,但经常需要向其添加新的操作。

  类图:

  

八、责任链模式

  定义:使多个对象都有机会处理请求,从而避免请求的发送者与接受者之间的耦合关系。将这个对象连成一条链传递该请求,直到有一个对象处理它为止。

  理解:对象引用同一类型的另一个对象,形成一条链。链中的每个对象实现了同样的方法,处理对链中第一个对象发起的同一个请求。

  适用:

    1. 有多个对象可处理请求,而处理程序只有在运行时才能确定。
    2. 向一组对象发出请求,而不想现显式指定处理请求的特定处理程序。

  类图:

九、备忘录模式

  定义:在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。、

  角色:有三个角色:发起人(Originatior)、备忘录(Memento)、看管人(Caretaker)。

  理解:发起人生成一个备忘录给看管人,看管人保存备忘录。当需要时,看管人获取备忘录交给发起人,发起人根据备忘录恢复自己。  

  类图:

  

十、状态模式

  定义:允许一个对象在其内部状态改变时改变他的行为。对象看起来似乎改变了它的类。

  角色:有2个角色:环境(context)、状态(state)

  理解:1.state可以理解为一个接口。2.context持有state的一个实例,动态的改state就动态的改了context的行为。

  类图:

  

十一、解释器模式

  定义:给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。

  角色:环境(context)、解释器

  理解:给定一个环境,创建不同的解释器并把环境传给解释器,不同的解释器对环境有不同的解释。

  类图:

时间: 2024-10-13 12:22:57

23种设计模式介绍(三)---- 行为型模式的相关文章

23种设计模式介绍(一)---- 创建型模式

由于设计模式篇幅比较大,如果在一篇文章讲完所有的设计模式的话不利于阅读.于是我把它分为三篇文章 23种设计模式介绍(一)---- 创建型模式 23种设计模式介绍(二)---- 结构型模式 23种设计模式介绍(三)---- 行为型模式 由于设计模式都是比较抽象的概念,所以大家一定要确保看懂类图,而后再自己写代码加强记忆. 简介 设计模式分为三大类: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接

23种设计模式介绍(二)---- 结构型模式

由于设计模式篇幅比较大,如果在一篇文章讲完所有的设计模式的话不利于阅读.于是我把它分为三篇文章 23种设计模式介绍(一)---- 创建型模式 23种设计模式介绍(二)---- 结构型模式 23种设计模式介绍(三)---- 行为型模式 设计模式都是比较抽象的概念,所以大家一定要确保看懂类图而后再自己写代码加强记忆. 概述 结构型模式共七种: 适配器模式(Adapter) 外观模式(Facade) 桥接模式(Bridge) 装饰器模式(Decorator) 代理模式(Proxy) 享元模式(Flyw

Java开发中的23种设计模式介绍

设计模式(Design Patterns) --可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦的一块块砖石一样.项目中合理的运用设计模式可以完美的解决很多问题,每种模式在现在中都有相应的原理来与之对应,每一个模式描述了一个在我们周

23种设计模式介绍以及在Java中的实现

原创不易,转载请注明出处:http://anxpp.com/,谢谢!     文章比较长,读者可以通过顶端的目录选择要了解的模式,然后通过文章右边的按钮快速返回顶部重新选择一个新的模式浏览 博主精心准备了大量的示例代码.文章尽量提供与编程相关的例子,而不是像多数其他介绍的文章一样,提供一些感觉挺滑稽的例子(那样的例子可能看完觉得写得很好,然而还是不会用...). 本文耗费了作者大量时间,还请亲们给个赞O(∩_∩)O~ 也可以通过CTRL+F并输入要了解的模式并跳到对应位置. 文章中的示例源码在g

23种设计模式介绍以及单例模式的学习

1.GOF23 设计模式总共分成创建型模式.结构型模式和行为型模式三种: a.创建型模式: - 单例模式.工厂模式.抽象工厂模式.建造者模式.原型模式 b.构建型模式: - 适配器模式.桥接模式.装配模式.组合模式.建造者模式.原型模式 c.行为性模式: - 模版方法模式.命令模式.迭代器模式.观察者模式.中介者模式.备忘录模式.解释器模式.状态模式.策略模式.职责链模式.访问者模式. 2.下面介绍单例模式:(在后面的博文中会一一介绍主要的设计模式) a.核心作用:保证一个类只有一个实例,并且提

23种设计模式[2]:工厂方法模式

一.简单工厂模式(静态工厂方法,不属于23种GOF设计模式之一) 定义:定义一个用于创建产品对象的方法,由该工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父类或接口)的实例. 类型:创建类模式 public interface SmsService { void sendSms(); } public class MontnetsService implements SmsService { @Override public void sendSms() { Syste

23种设计模式[3]:抽象工厂模式

一.简单工厂模式(静态工厂方法,不属于23种GOF设计模式之一) 定义:定义一个用于创建产品对象的方法,由该工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父类或接口)的实例. 类型:创建类模式 public interface SmsService { void sendSms(); } public class MontnetsService implements SmsService { @Override public void sendSms() { Syste

(35)23种设计模式研究之六【命令模式】

命令模式 一:定义 将一个请求封装为一个对象(即我们创建的Command对象),从而使你可用不同的请求对客户进行参数化; 对请求排队或记录请求日志,以及支持可撤销的操作. 二:实现 解决的问题 在软件系统中,行为请求者与行为实现者通常是一种紧耦合的关系,但某些场合,比如需要对行为进行记录.撤销或重做.事务等处理时,这种无法抵御变化的紧耦合的设计就不太合适. 模式中角色 1 抽象命令(Command):定义命令的接口,声明执行的方法. 2 具体命令(ConcreteCommand):具体命令,实现

23种设计模式(4)-生成器模式

定义: 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.生成器模式利用一个导演者对象和具体建造者对象一个一个地建造出所有的零件,从而建造出完整的对象. 四个要素: Builder:生成器接口,定义创建一个Product对象所需要的各个部件的操作. ConcreteBuilder:具体的生成器实现,实现各个部件的创建,并负责组装Product对象的各个部件,同时还提供一个让用户获取组装完成后的产品对象的方法. Director:指导者,也被称导向者,主要用来使用Build