备忘录模式 rust和java的实现

文章目录

备忘录模式

备忘录(Memento)模式的定义:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,以便以后当需要时能将该对象恢复到原先保存的状态。该模式又叫快照模式。

备忘录模式能记录一个对象的内部状态,当用户后悔时能撤销当前操作,使数据恢复到它原先的状态。

介绍

  • 意图:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。

  • 主要解决:所谓备忘录模式就是在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样可以在以后将对象恢复到原先保存的状态。

  • 何时使用:很多时候我们总是需要记录一个对象的内部状态,这样做的目的就是为了允许用户取消不确定或者错误的操作,能够恢复到他原先的状态。

  • 应用实例: 1、打游戏时的存档。 2、Windows 里的 ctrl + z。 3、浏览器中的后退。 4、数据库的事务管理。

实现

备忘录模式使用三个类 Memento、Originator 和 CareTaker。Memento 包含了要被恢复的对象的状态。Originator 创建并在 Memento 对象中存储状态。Caretaker 对象负责从 Memento 中恢复对象的状态。

MementoPatternDemo,我们的演示类使用 CareTaker 和 Originator 对象来显示对象的状态恢复。

java

步骤 1

创建 Memento 类。

Memento.java

java 复制代码
public class Memento {
   private String state;
 
   public Memento(String state){
      this.state = state;
   }
 
   public String getState(){
      return state;
   }  
}

步骤 2

创建 Originator 类。

Originator.java

java 复制代码
public class Originator {
   private String state;
 
   public void setState(String state){
      this.state = state;
   }
 
   public String getState(){
      return state;
   }
 
   public Memento saveStateToMemento(){
      return new Memento(state);
   }
 
   public void getStateFromMemento(Memento Memento){
      state = Memento.getState();
   }
}

步骤 3

创建 CareTaker 类。

CareTaker.java

java 复制代码
import java.util.ArrayList;
import java.util.List;
 
public class CareTaker {
   private List<Memento> mementoList = new ArrayList<Memento>();
 
   public void add(Memento state){
      mementoList.add(state);
   }
 
   public Memento get(int index){
      return mementoList.get(index);
   }
}

步骤 4

使用 CareTaker 和 Originator 对象。

MementoPatternDemo.java

java 复制代码
public class MementoPatternDemo {
   public static void main(String[] args) {
      Originator originator = new Originator();
      CareTaker careTaker = new CareTaker();
      originator.setState("State #1");
      originator.setState("State #2");
      careTaker.add(originator.saveStateToMemento());
      originator.setState("State #3");
      careTaker.add(originator.saveStateToMemento());
      originator.setState("State #4");
 
      System.out.println("Current State: " + originator.getState());    
      originator.getStateFromMemento(careTaker.get(0));
      System.out.println("First saved State: " + originator.getState());
      originator.getStateFromMemento(careTaker.get(1));
      System.out.println("Second saved State: " + originator.getState());
   }
}

步骤 5

验证输出。

shell 复制代码
Current State: State #4
First saved State: State #2
Second saved State: State #3

rust

rust的实现和java的实现大致一样,就不再赘述了

rs 复制代码
// 设置备忘录类
#[derive(Clone)]
struct Memento{
        state:String
}
// 设置创始类
struct Originator{
    state:String,
}
impl Originator {
    fn save_state_to_memento(&self)->Memento{
        Memento { state: self.state.clone() }
    }
    fn get_state_from_memento(&mut self,memento:Memento){
        self.state=memento.state.clone();
    }
}
// 创建看护人类
struct CareTaker{
    memento_list:Vec<Memento>
}
impl CareTaker {
    fn add(&mut self,memento:Memento){
        self.memento_list.push(memento);
    }
    fn get(&self,index:usize)->Memento{
        self.memento_list.get(index).unwrap().clone()
    }
}

fn main() {
    let mut originator=Originator{state:"State #1".to_owned()};
    let mut careTaker =CareTaker{memento_list:vec![]}; 
    originator.state=String::from("State #2");
    careTaker.add(originator.save_state_to_memento());
    originator.state=String::from("State #3");
    careTaker.add(originator.save_state_to_memento());
    originator.state=String::from("State #4");
    println!("Current State: {}",originator.state);
    originator.get_state_from_memento(careTaker.get(0));
    println!("First saved State: {}",originator.state);
    originator.get_state_from_memento(careTaker.get(1));
    println!("Second saved State: {}",originator.state)
}

rust仓库

https://github.com/onenewcode/design.git

本教程项目在bin文件夹下的mediator.rs文件中

相关推荐
敖正炀1 分钟前
SynchronousQueue 详解
java
wuyikeer3 分钟前
Spring Boot 经典九设计模式全览
java·spring boot·设计模式
努力努力再努力wz12 分钟前
【Linux网络系列】深入理解 I/O 多路复用:从 select 痛点到 poll 高并发服务器落地,基于 Poll、智能指针与非阻塞 I/O与线程池手写一个高性能 HTTP 服务器!(附源码)
java·linux·运维·服务器·c语言·c++·python
努力努力再努力wz15 分钟前
【Linux网络系列】万字硬核解析网络层核心:IP协议到IP 分片重组、NAT技术及 RIP/OSPF 动态路由全景
java·linux·运维·服务器·数据结构·c++·python
LaLaLa_OvO20 分钟前
mybatis 引用静态常量
java·mybatis
Han_han91923 分钟前
常用API:
java·开发语言
minji...27 分钟前
Linux 线程同步与互斥(四) POSIX信号量,基于环形队列的生产者消费者模型
linux·运维·服务器·c语言·开发语言·c++
东京老树根30 分钟前
SAP学习笔记 - BTP SAP Build05 - SAP BTP BPA简介,Email Destination Settings(TODO)
笔记·学习
小锋java123436 分钟前
LangChain4j 来了,Java AI智能体开发再次起飞。。。
java·人工智能·后端
Highcharts.js37 分钟前
在 React 中使用 useState 和 @highcharts/react 构建动态图表
开发语言·前端·javascript·react.js·信息可视化·前端框架·highcharts