原型模式

实现Cloneable接口并重写clone()方法,就完成了原型模式。
通用源码:

public class ProtoTypeClass implements Cloneable{@Overridepublic ProtoTypeClass clone(){ProtoTypeClass protoType = null;try{protoType = (ProtoTypeClass)super.clone();}catch(CloneNotSupportedException e){//异常处理}return protoType;}
}
  • 优点:原型模式是在内存二进制流的拷贝,要比直接new一个对象性能好很多。尤其是要在一个循环体内产生大量的对象时。
  • 缺点:逃避构造函数的约束。直接在内存中拷贝,构造函数是不会执行的。Object类的clone方法的原理就是从内存中以二进制流的方式进行拷贝,重新分配一个内存块。
  • 应用场景:
    1. 类初始化需要消化非常多的资源,这个资源包括数据、硬件资源等。
    2. 通过new产生一个对象需要非常多繁琐的数据准备货访问权限。
    3. 一个对象多个修改者。有可能产生数据不一致的问题。可以考虑使用原型模式拷贝多个对象供调用者使用。

实际项目中原型模式很少单独出现,一般是和工厂方法模式一起出现,通过clone的方法创建一个对象,然后由工厂方法提供给调用者。

浅拷贝和深拷贝
浅拷贝:Object类提供的方法clone只是拷贝本对象,其对象内部的数组、引用对象等都不拷贝。还是指向原生对象的内部地址。而其他的原始类型比如int,long,char等都会被拷贝,但对于String类型,java希望你把它认为是基本的原始类型,它是没有clone()方法的。处理机制也比较特殊,通过字符串池(stringpool)在需要的时候才在内存中创建新的字符串。
注:使用原型模式时,引用的成员变量必须满足两个条件才不会被拷贝:一是类的成员变量,而不是方法内变量;而是必须是一个可变的引用对象,而不是原始类型或不可变对象。

public class Thing implements Cloneable{private ArrayList<String> arrayList = new ArrayList<String>();@Overridepublic Thing clone(){Thing thing=null;try {thing = (Thing)super.clone();} catch (CloneNotSupportedException e) {e.printStackTrace();}return thing;}public void setValue(String value){this.arrayList.add(value);}public ArrayList<String> getValue(){return this.arrayList;}
}
public static void main(String[] args) {Thing thing = new Thing();thing.setValue("李四");Thing cloneThing = thing.clone();cloneThing.setValue("张三");System.out.println(thing.getValue());//结果是[李四,张三]}

深拷贝:改下上面clone()方法的代码即可实现深拷贝。

public Thing clone(){Thing thing=null;try {thing = (Thing)super.clone();   this.arrayList = (ArrayList<String>)this.arrayList.clone();} catch (CloneNotSupportedException e) {e.printStackTrace();}return thing;}

注:要实现深拷贝,类的成员变量不要增加final关键字,否则会报错。
最佳实践:原型模式先产生出一个包含大量共有信息的类,然后可以拷贝出副本,修正细节信息,建立一个完整的个性对象。

中介者模式

迪米特法则认为每个类只和朋友类交流。
中介者模式定义:用一个中介对象封装一系列的对象交互,中介者使各对象不需要显示的相互作用,使其耦合松散,而且可以独立的改变他们之间的交互。
中介者模式通用类图:
ConcreteMediator—>Mediator<——-Colleague
Mediator:抽象中介者,定义统一的接口,用于各同事角色之间的通信。
Concrete Mediator:具体中介者,协调各同事角色实现协作行为,因此它必须依赖于各个同事角色。
Colleague:每一个同事角色都知道中介者角色,每一个同事类的行为分为两种:一种是同事本身的行为,比如改变对象本身的状态,处理自己的行为等。一种是必须依赖中介者才能完成的行为,叫做依赖方法。
通用代码:

public abstract class Mediator {//定义同事类protected ConcreteColleague1 c1;protected ConcreteColleague2 c2;//通过getter/setter把同事类注入进来public ConcreteColleague1 getC1() {return c1;}public void setC1(ConcreteColleague1 c1) {this.c1 = c1;}public ConcreteColleague2 getC2() {return c2;}public void setC2(ConcreteColleague2 c2) {this.c2 = c2;}//中介者模式的业务逻辑public abstract void doSomething1();public abstract void doSomething2();}
public class ConcreteMediator extends Mediator {@Overridepublic void doSomething1() {//调用同事类的方法super.c1.selfMethod1();super.c2.selfMethod2();}public void doSomething2() {super.c1.selfMethod1();super.c2.selfMethod2();}}
public abstract class Colleague {protected Mediator mediator;public Colleague(Mediator _mediator){this.mediator = _mediator;}
}
public class ConcreteColleague1 extends Colleague {//通过构造函数传递中介者public ConcreteColleague1(Mediator _mediator){super(_mediator);}//自有方法public void selfMethod1(){//处理自己的业务逻辑}//依赖方法 dep-methodpublic void depMethod1(){//处理自己的业务逻辑//自己不能处理的业务逻辑,委托给中介者处理super.mediator.doSomething1();}}
public class ConcreteColleague2 extends Colleague {public ConcreteColleague2(Mediator _mediator){super(_mediator);}public void selfMethod2(){//处理自己的业务逻辑}public void depMethod2(){//处理自己的业务逻辑super.mediator.doSomething2();}}
  • 优点:减少类间的依赖,把原有的一对多的依赖变成了一对一的依赖,同事类只依赖中介者。降低了类间的耦合。
  • 缺点:中介者会膨胀的很大,同事类越多,中介者的逻辑就越复杂。
  • 应用:中介者模式的使用要量力而行。适用于多个对象之间的紧密耦合的情况。紧密耦合的标准是:在类图中出现了蜘蛛网结构。把蜘蛛网梳理为星型结构。
  • 实际应用:
    机场调度中心。
    MVC框架:struts的C(Controller)就是一个中介者。把Model和Vie
    w隔离开,协调M和V协同工作,减少他们之间的依赖。
    媒体网关、中介服务等
  • 最佳实践:
    1. N个对象之间产生了相互的依赖关系(N>2)
    2. 多个对象有依赖关系,但是依赖的行为尚不确定或者有发生改变的可能。可使用中介者模式降低变更引起的风险扩散。
    3. 产品开发。把中介者模式应用到产品中,可以提升产品的性能和扩展性。

命令模式

定义:将一个请求封装成一个对象,从而让你使用不同的请求吧客户端参数化,对请求排队或者记录请求日志,可以提供命令的撤销和恢复功能。
命令模式的通用类图:

Receiver:接受者角色。干活的角色。命令传到这里是应该被执行的。
Command命令角色:需要执行的所有命令都在这里执行。
Invoker调用者角色:接收到命令并执行命令。
通用代码

public abstract class Receiver{//抽象接受者,定义每个接受者都必须完成的业务public abstract void doSomething();
}
public class ConcreteReciver1 extends Receiver{//每个接收者必须处理一定的业务逻辑public void doSomething(){}
}
public class ConcreteReciver2 extends Receiver{public void doSomething(){}
}
public abstract class Command {//每个命令类都必须有一个执行命令的方法public abstract void execute();
}
public class ConcreteCommand1 extends Command {//对哪个receiver进行命令处理private Receiver receiver;//构造函数传递接收者public ConcreteCommand1(Receiver _receiver){this.receiver = _receiver;}//必须执行一个命令public void execute() {this.receiver.doSomething();}}
public class ConcreteCommand2 extends Command {private Receiver receiver;public ConcreteCommand2(Receiver _receiver){this.receiver = _receiver;}public void execute() {//ÒµÎñ´¦Àíthis.receiver.doSomething();}}
public class Invoker {private Command command;//接收命令public void setCommand(Command _command){this.command = _command;}//执行命令public void action(){this.command.execute();}}
public class Client {public static void main(String[] args) {Invoker invoker = new Invoker();Receiver receiver = new ConcreteReciver1();Command command = new ConcreteCommand1(receiver);invoker.setCommand(command);invoker.action();}}

优点:
1. 类间解耦,调用者角色与接收者角色之间没有任何依赖关系。调用者实现功能时只需调用Command抽象类的execute方法就可以了。
2. 可扩展性:Command的子类非常容易扩展。
3. 命令模式可以结合责任链模式,实现命令族解析,结合模板方法模式,则可以减少Command子类的膨胀问题。
缺点:Command的子类会膨胀。

设计模式之禅读书笔记1相关推荐

  1. 设计模式之禅读书笔记—行为类模式

    设计模式之禅读书笔记-行为类模式 PDF下载地址 责任链模式 命令模式 解释器模式 迭代器模式 中介者模式 备忘录模式 观察者模式 状态模式 策略模式 模板方法模式 访问者模式 责任链模式 定义:使多 ...

  2. 设计模式之禅读书笔记

    >设计原则< >Single Responsibility Principle(单一职责原则)类只有一个修改的原因. ●类的复杂性降低,实现什么职责都有明确的定义. ●可读性高 ●可 ...

  3. 《设计模式之禅》笔记序言(附源码链接)

    <设计模式之禅>笔记序言(附源码链接) GitHub链接 2021年9月初,我下定决心要从书本出发,建立自己的技术栈基础体系.在此过程中,从阅读的部分书籍的源代码导读中,我发现其中有迹可循 ...

  4. 设计模式之美读书笔记

    目录 设计模式之美 读书笔记5- 哪些代码看似面向对象,实际是面向过程编程? 读书笔记4- 封装.抽象.继承.多态分别解决了什么编程问题? 读书笔记3- 我们在讨论面向对象的时候,主要说的是什么? 读 ...

  5. 《设计模式之禅》笔记

    本片基于<设计模式之禅>所总结的笔记.其中总结了面试一般的常见的问题,虽然只是单调的文字,但是精简了很多概念,本文比较适合有一定设计模式基础的人,当做一个复习的笔记随时可查看. 单例模式 ...

  6. 设计模式沉思录 - 读书笔记(XMind)

    注:后面会不定期,以XMind的方式发布一些读书笔记. 目标:书还要是越读越薄才行!

  7. 设计模式之禅学习笔记

    设计模式 一,六大设计原则[SOLID] 1,单一职责[SRP]:应该有且仅有一个原因引起类的变更. "职责"和"变化原因"都是不可度量的,因项目和实际环境而异 ...

  8. 《设计模式解析》读书笔记

    Facade模式 GoF模式中的定义: 为子系统中的一组接口提供一个统一的接口.Facade模式定义了一个更高层的接口,使子系统更容易使用. 通过Facade,我们将以一种更简单的方式来使用原有系统. ...

  9. 《深入浅出设计模式-中文版》读书笔记-工厂模式(五)

    今天给大家带来的是:工厂模式. 我们在代码中创建一个对象,我们会很自然的想到new.其实,除了new意外,我们还有很多的方式可以创建对象.不说复杂的模式,就说简单的语法,其实.NET框架中还有下面的方 ...

最新文章

  1. 如何找回丢失的Vista系统“休眠”菜单
  2. Kali Linux 装好系统后安装经常使用软件
  3. 类中匿名函数如何从 event 中去除
  4. matlab采样序列幅频特性,数字信号处理课设计指导书20130530.doc
  5. js获取时间(本周、本季度、本月..)
  6. sql 列求和_图解面试题:累计求和问题如何分析?
  7. Android无界面编程之使用Service
  8. 【Linux】Linux设备驱动开发详解:基于最新的Linux 4.0内核
  9. 七、项目沟通管理(输入/工具与技术/输出)
  10. 通过V90PN通讯故障实例来看线路干扰与线路错误的区别
  11. S5P4418 Android实时时钟框架介绍
  12. 监护仪系统都是Linux吗,基于Linux和MCU的心电监护仪设计
  13. 职场干货 | 如何让你的自我介绍,快速打动面试官
  14. 参考文献为外文文献时应该采用什么格式啊?
  15. vue页面换成手机适配屏幕
  16. CSDN-markdown语法之如何使用LaTeX语法编写数学公式
  17. 关于ARGB_8888、ALPHA_8、ARGB_4444、RGB_565的理解
  18. 标准应用促边缘云成熟度提升
  19. web服务器常见配置搭建详解(超详细)
  20. nginx的Gzip配置

热门文章

  1. java 鼠标悬停事件_java swing中如何实现对于鼠标监听悬停事件
  2. SQL SERVER 定时自动备份,并将备份文件加密压缩(利用winrar)
  3. flag!flag!flag!flag!flag!flag!flag!flag!flag!flag!flag!flag!
  4. 计算机策略更新失败怎么办,Win10系统自动更新失败 步骤 1、首先要停止Windows update服务...
  5. VC数据库编程总结(二)
  6. 在VMware中制作linux虚拟机模板
  7. DirectX的初始化
  8. 小米智能音箱能否成下一个小米手机?
  9. IMEI Android ID
  10. 如何在Python中实现RFM分析