当前位置: 首页 > article >正文

备忘录模式 rust和java的实现

文章目录

    • 备忘录模式
      • 介绍
      • 实现
      • java
      • rust
      • rust仓库

备忘录模式

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

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

介绍

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

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

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

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

实现

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

MementoPatternDemo,我们的演示类使用 CareTaker 和 Originator 对象来显示对象的状态恢复。
在这里插入图片描述

java

步骤 1
创建 Memento 类。
Memento.java

public class Memento {
   private String state;
 
   public Memento(String state){
      this.state = state;
   }
 
   public String getState(){
      return state;
   }  
}

步骤 2
创建 Originator 类。

Originator.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

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

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
验证输出。

Current State: State #4
First saved State: State #2
Second saved State: State #3

rust

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

// 设置备忘录类
#[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文件中


http://www.kler.cn/a/162154.html

相关文章:

  • 深度学习——优化算法、激活函数、归一化、正则化
  • 前端开发中常用的包管理器(npm、yarn、pnpm、bower、parcel)
  • 每日一练:二分查找-搜索插入位置
  • STM32单片机WIFI语音识别智能衣柜除湿消毒照明
  • Springboot集成syslog+logstash收集日志到ES
  • 实现一个BLE HID鼠标
  • 机器学习实战:预测波士顿房价
  • Linus:我休假的时候也会带着电脑,否则会感觉很无聊
  • [论文阅读]Sparse Fuse Dense
  • 快速排序的新用法
  • CleanMyMac软件2024最新Mac系统清理工具实用性测评
  • FFmpeg数据结构AVFrame
  • SpringBoot项目访问resources下的静态资源
  • 企业计算机服务器中了360勒索病毒如何解密,勒索病毒解密数据恢复
  • 十五届蓝桥杯分享会(一)
  • React中每次渲染都会传入一个新的props.children到子组件?
  • Sentinel基础知识
  • WT588F02B单片机语音芯片在磁疗仪中的应用介绍
  • 【算法每日一练]-结构优化(保姆级教程 篇6 分块,倍增)#HDU4417超级马里奥 #poj2019玉米田 #POJ3368频繁值
  • Linux下的同步命令代码编写
  • 借助webpack来优化前端性能
  • Linux学习教程(第十一章 Linux高级文件系统管理)二
  • C语言第四十四弹---调整奇偶数顺序
  • 广州数字孪生赋能工业制造,加速推进制造业数字化转型
  • Spark---Spark on Hive
  • 利用proteus实现串口助手和arduino Mega 2560的串口通信