大话设计模式目录_大话设计模式程杰mobi

大话设计模式目录_大话设计模式程杰mobi大话设计模式之备忘录模式

大家好,又见面了,我是你们的朋友全栈君。

备忘录模式

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

大话设计模式目录_大话设计模式程杰mobi

涉及到的角色描述

  originator(发起人):   负责创建一个备忘录memento,用来记录当前时刻它的内部状态,并可使用备忘录恢复内部状态。originator可根据需要决定memento存储它的哪些内部状态

  memento(备忘录): 负责存储originator的内部状态,并可防止originator以外的其他对象访问备忘录memento。备忘录有两个接口,caretaker只能看到备忘录的窄接口,他只能将备忘录传递给其他对象。originator能够看到一个宽接口,允许它访问返回先前状态所需的所有数据。

  caretaker(管理者): 负责保存好备忘录memento,不能对备忘录的内容进行操作或检查。

优点: 

  1、给用户提供了一种可以恢复状态的机制,可以使用户能够比较方便地回到某个历史的状态。

  2、实现了信息的封装,使得用户不需要关心状态的保存细节。

缺点:

  消耗资源。如果类的成员变量过多,势必会占用比较大的资源,而且每一次保存都会消耗一定的内存。

使用场景: 

  1、需要保存/恢复数据的相关状态场景。

  2、提供一个可回滚的操作。

具体代码实现

  创建备忘录

package com.chenpt.designModel.mementoModel;

/**
 * @Author: chen
 * @Description: 备忘录类
 * @Date: created in 2018/8/28
 * @Modified By:
 */
public class Memento {

    private String state;

    //构造方法将相关数据导入
    Memento(String state){
        this.state = state;
    }

    //需要保存的数据属性,可以是多个
    public String getState() {
        return state;
    }


}

  创建发起人

package com.chenpt.designModel.mementoModel;

/**
 * @Author: chen
 * @Description: 发起人
 * @Date: created in 2018/8/28
 * @Modified By:
 */
public class Originator {
    private String state;//需要保存的属性

    public String getState() {
        return state;
    }

    public void setState(String state) {
        this.state = state;
    }

    /**
     * 创建备忘录,将当前需要保存的数据导入并实例化一个memento对象
     * @return
     */
    public Memento setStateToMemento(){
        return new Memento(state);
    }

    /**
     * 恢复备忘录,将memento导入并将相关数据恢复
     * @param memento
     */
    public void getStateFromMemento(Memento memento){
        state = memento.getState();
    }

    /**
     * 数据展示
     */
    public void show(){
        System.out.println(state);
    }
}

  创建管理者

package com.chenpt.designModel.mementoModel;

/**
 * @Author: chen
 * @Description: 管理者
 * @Date: created in 2018/8/28
 * @Modified By:
 */
public class CareTaker {
    private Memento memento;//得到或设置备忘录

    public Memento getMemento() {
        return memento;
    }

    public void setMemento(Memento memento) {
        this.memento = memento;
    }
}

  客户端

package com.chenpt.designModel.mementoModel;

/**
 * @Author: chen
 * @Description:
 * @Date: created in 2018/8/28
 * @Modified By:
 */
public class MainTest {

    public static void main(String[] a){
        Originator originator = new Originator();
        originator.setState("on");
        originator.show();

        CareTaker careTaker = new CareTaker();
        careTaker.setMemento(originator.setStateToMemento());

        originator.setState("off");
        originator.show();

        originator.getStateFromMemento(careTaker.getMemento());
        originator.show();
    }

}
//执行结果
on
off
on

  

 

转载于:https://www.cnblogs.com/chenpt/p/9547988.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107341.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 《JavaScript设计模式》初次笔记——wsdchong[通俗易懂]

    《JavaScript设计模式》初次笔记——wsdchong[通俗易懂]《JavaScript设计模式》初次笔记前言设计模式一直久仰大名,但是没有去花时间去了解,于是今天特意花时间去看《JavaScript设计模式》(2013年6月出版)和w3cschool上的设计模式。然后做了一些笔记。以《JavaScript设计模式》为目录,以w3cschool上的设计模式为补充。讲的内容有三:设计模式、JavaScript设计模式、其他(模块化的JavaScript设计模式、jQuery设计模式、jQuery插件设计模式)。学习目的:尝试性地了解JavaScript设计模式,方

    2022年7月12日
    19
  • Java设计模式之迭代子模式

    本文继续介绍23种设计模式系列之观察者模式。定义在软件构建过程中,集合对象内部结构常常变化各异,但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以让外部客户代码透明地访问其中包含的元素;同时这种“透明遍历”也为同一种算法在多种集合对象上进行操作提供了可能。使用面向对象技术将这种遍历机制抽象为“迭代器对象”为“应对变化中的集合对象”提供了一种优雅的方式。迭代子(Iterator)模式又叫游标

    2022年3月11日
    36
  • Java设计模式之行为型:解释器模式

    Java设计模式之行为型:解释器模式

    2021年10月4日
    36
  • 设计模式——门面模式「建议收藏」

    设计模式——门面模式「建议收藏」今天我们继续来学习前面没有学完的结构型设计模式中的一种:门面模式。门面模式也是一种不太常用的设计模式。所以,我们今天依旧是了解为主,暂时不去深入的学习。概述门面模式:(FacadeDesignPattern)门面模式也叫外观模式,门面模式为子系统提供一组统一的接口,定义一组高层接口让子系统更易用。门面模式原理和实现也比较简单,应用场景也比较明确,主要在接口设计方面使用。何时使用:解决易用性问题。解决性能问题。解决分布式事务问题。UML类图:角色组成:门面角色:客户端调用这个

    2025年6月6日
    3
  • 设计模式之代理模式XXOO

    设计模式之代理模式XXOO定义代理模式可以分为两种,一种是静态代理,一种是动态代理。静态代理:代理类一般会持有一个被代理的对象引用,且对于不关心的方法全部委托给被代理的对象处理。自己处理关心的方法。这种代理方式是死板的,它不是在运行时动态创建,它就是硬编码,你代码编译前写的是什么,编译后就是什么。换句话就是你按下CTRL+S的那一刻,就会被代理对象生成一个不可动态改变的代理类。静态代理一般对于代理的对象是单个或者多个固定的类(数量不会太多)使用。效果会比动态代理要好。动态代理:动态代理又分为JDK动

    2022年7月17日
    12
  • 设计模式 – 结构型设计模式 – 适配器模式(Java)

    设计模式 – 结构型设计模式 – 适配器模式(Java)分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请点击http://www.captainbed.netDefinitionSeparatetheconstructionofacomplexobjectfromitsrepresentationsothatthesameconstructionprocesscan…

    2022年7月25日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号