设计模式-行为型模式-备忘录模式

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

复制代码
//首先,我们定义Originator类,它有一个状态和一个方法来创建和恢复备忘录:
public class Originator {
    private String state;

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

    public String getState() {
        return state;
    }

    // 创建备忘录
    public Memento createMemento() {
        return new Memento(this.state);
    }

    // 恢复备忘录状态
    public void restoreMemento(Memento memento) {
        this.state = memento.getState();
    }
}
//接下来,我们定义Memento类,它负责存储Originator的状态:
public class Memento {
    private String state;

    // 构造器,用于从Originator获取状态信息
    public Memento(String state) {
        this.state = state;
    }

    // 获取备忘录中的状态信息
    public String getState() {
        return state;
    }
}
//然后,我们定义Caretaker类,它负责管理Memento对象:
public class Caretaker {
    private Memento memento;

    // 保存备忘录
    public void setMemento(Memento memento) {
        this.memento = memento;
    }

    // 获取备忘录
    public Memento getMemento() {
        return memento;
    }
}
//最后,我们编写一个简单的客户端代码来演示如何使用这些类:
public class MementoPatternDemo {
    public static void main(String[] args) {
        // 创建Originator对象
        Originator originator = new Originator();
        // 创建Caretaker对象
        Caretaker caretaker = new Caretaker();

        // 设置Originator的初始状态
        originator.setState("State A");
        System.out.println("Originator state: " + originator.getState());

        // 创建备忘录并保存
        caretaker.setMemento(originator.createMemento());

        // 改变Originator的状态
        originator.setState("State B");
        System.out.println("Originator state: " + originator.getState());

        // 从Caretaker恢复备忘录
        originator.restoreMemento(caretaker.getMemento());
        System.out.println("Originator state after restoring memento: " + originator.getState());
    }
}
相关推荐
atunet12 分钟前
关于算法设计模式的演化与编程范式变迁的技术7
算法·设计模式
geovindu7 小时前
go:Timing Functions Pattern
开发语言·后端·设计模式·golang·计时函数模式·性能分析模式
咖啡八杯2 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
槑有老呆2 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron2 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程
咖啡八杯4 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
胡萝卜术4 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
亦暖筑序5 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
青禾网络7 天前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
ZJPRENO8 天前
吃透软件开发六大设计原则,告别烂代码
设计模式