状态模式与备忘录模式(3)

简介: 状态模式与备忘录模式(3)

最后创建备忘录管理角色草稿箱DraftsBox类:


public class DraftsBox {
    private final Stack<ArticleMemento> STACK = new Stack<ArticleMemento>();
    public ArticleMemento getMemento(){
        ArticleMemento articleMemento = STACK.pop();
        return articleMemento;
    }
    public void addMemento(ArticleMemento articleMemento){
        STACK.push(articleMemento);
    }
}


草稿箱中定义的Stack类是Vector的一个子类,它实现了一个标准的后进先出的栈。主要

定义了以下方法:


image.png


最后,编写客户端测试代码:


public class Test {
    public static void main(String[] args) {
        DraftsBox draftsBox = new DraftsBox();
        Editor editor = new Editor("我是这样手写Spring的,麻雀虽小五脏俱全",
                "本文节选自《Spring5核心原理与30个类手写实战》一书,Tom著,电子工业出版社出版。",
                "35576a9ef6fc407aa088eb8280fb1d9d.png");
        ArticleMemento articleMemento = editor.saveToMemento();
        draftsBox.addMemento(articleMemento);
        System.out.println("标题:" + editor.getTitle() + "\n" +
                            "内容:" + editor.getContent() + "\n" +
                            "插图:" + editor.getImgs() + "\n暂存成功");
        System.out.println("完整的信息" + editor);
        System.out.println("==========首次修改文章===========");
        editor.setTitle("【Tom原创】我是这样手写Spring的,麻雀虽小五脏俱全");
        editor.setContent("本文节选自《Spring5核心原理与30个类手写实战》一书,Tom著");
        System.out.println("==========首次修改文章完成===========");
        System.out.println("完整的信息" + editor);
        articleMemento = editor.saveToMemento();
        draftsBox.addMemento(articleMemento);
        System.out.println("==========保存到草稿箱===========");
        System.out.println("==========第2次修改文章===========");
        editor.setTitle("手写Spring");
        editor.setContent("本文节选自《Spring5核心原理与30个类手写实战》一书,Tom著");
        System.out.println("完整的信息" + editor);
        System.out.println("==========第2次修改文章完成===========");
        System.out.println("==========第1次撤销===========");
        articleMemento = draftsBox.getMemento();
        editor.undoFromMemento(articleMemento);
        System.out.println("完整的信息" + editor);
        System.out.println("==========第1次撤销完成===========");
        System.out.println("==========第2次撤销===========");
        articleMemento = draftsBox.getMemento();
        editor.undoFromMemento(articleMemento);
        System.out.println("完整的信息" + editor);
        System.out.println("==========第2次撤销完成===========");
    }
}


备忘录模式在源码中的体现

在 Spring的 webflow源 码 中 还 是 找 到 一 个StateManageableMessageContext 接口 ,我们来看它的源代码:


public interface StateManageableMessageContext extends MessageContext {
    Serializable createMessagesMemento();
    void restoreMessages(Serializable var1);
    void setMessageSource(MessageSource var1);
}


我们看到有一个createMessagesMementoQ方法,创建一个消息备忘录。可以打开它的实

现类:


public class DefaultMessageContext implements StateManageableMessageContext {
   private static final Log logger = LogFactory.getLog(DefaultMessageContext.class);
   private MessageSource messageSource;
   @SuppressWarnings("serial")
   private Map<Object, List<Message>> sourceMessages = new AbstractCachingMapDecorator<Object, List<Message>>(
         new LinkedHashMap<Object, List<Message>>()) {
      protected List<Message> create(Object source) {
         return new ArrayList<Message>();
      }
   };
  public void clearMessages() {
    sourceMessages.clear();
  }
  // implementing state manageable message context
  public Serializable createMessagesMemento() {
    return new LinkedHashMap<Object, List<Message>>(sourceMessages);
  }
  @SuppressWarnings("unchecked")
  public void restoreMessages(Serializable messagesMemento) {
    sourceMessages.putAll((Map<Object, List<Message>>) messagesMemento);
  }
  public void setMessageSource(MessageSource messageSource) {
    if (messageSource == null) {
      messageSource = new DefaultTextFallbackMessageSource();
    }
    this.messageSource = messageSource;
  }        
}       


我们看到其主要逻辑就相当于是给Message留一个备份,以备恢复之用。


命令模式的优缺点

优点:


1、简化发起人实体类(Originator ) 职 责 ,隔离状态存储与获取,实现了信息的封装,客户端

无需关心状态的保存细节;


2、提供状态回滚功能;


缺点:


1、消耗资源:如果需要保存的状态过多时,每一次保存都会消耗很多内存。


十二、状态模式与备忘录模式详解


目录
相关文章
|
Windows
基于.Net Core实现自定义皮肤WidForm窗口
基于.Net Core实现自定义皮肤WidForm窗口
277 0
|
算法 数据挖掘 Python
在Python中使用K-Means聚类和PCA主成分分析进行图像压缩(二)
在Python中使用K-Means聚类和PCA主成分分析进行图像压缩(二)
438 0
在Python中使用K-Means聚类和PCA主成分分析进行图像压缩(二)
|
7天前
|
云安全 人工智能 自然语言处理
|
11天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
986 35
|
5天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
657 4
|
7天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
524 25
|
14天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
858 59
Meta SAM3开源:让图像分割,听懂你的话
|
4天前
|
弹性计算 网络协议 Linux
阿里云ECS云服务器详细新手购买流程步骤(图文详解)
新手怎么购买阿里云服务器ECS?今天出一期阿里云服务器ECS自定义购买流程:图文全解析,阿里云服务器ECS购买流程图解,自定义购买ECS的设置选项是最复杂的,以自定义购买云服务器ECS为例,包括付费类型、地域、网络及可用区、实例、镜像、系统盘、数据盘、公网IP、安全组及登录凭证详细设置教程:
195 114