备忘录模式

}

public class Memento {

private String state;

public Memento(String state){

this.state = state;

}

public String getState() {

return state;

}

public void setState(String state) {

this.state = state;

}

}

public class Caretaker {

private Memento memento;

/**

  • 获取备忘录

*/

public Memento getMemento(){

return this.memento;

}

/**

  • 保存备忘录

*/

public void saveMemento(Memento memento){

this.memento = memento;

}

}

public class Client {

public static void main(String[] args) {

Originator originator = new Originator();

Caretaker caretaker = new Caretaker();

//改变发起人对象的状态

originator.setState(“stateA”);

//创建备忘录对象,并将发起人对象的状态储存起来

caretaker.saveMemento(originator.createMemento());

//修改发起人的状态

originator.setState(“stateB”);

//恢复发起人对象的状态

originator.restoreMemento(caretaker.getMemento());

System.out.println(“恢复状态:”+originator.getState());

}

}

输出结果:

这里写图片描述

多状态的备忘录模式

上面的示例代码展示的情况比较简单,Originator中只有一个state成员变量需要保存,但实际中可能不止一个,会有很多个状态变量需要处理,那么在备份的时候就需要将所有的变量都存储起来,一种方法就是将变量名和对应的值都保存到一个map当中。当然还有比较简单的方法就是利用原型模式,我们可以将当前对象clone一个一模一样的对象来保存备份,通过clone的方式甚至都不需要备忘录管理者角色。下面是示例代码:

public class Originator implements Cloneable {

private Originator backup;

private String state;

private String state2;

private String state3;

/**

  • 创建备份

*/

public void createMemento() {

try {

this.backup = this.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

}

/**

  • 恢复备份

*/

public void restoreMemento(){

this.setState(this.backup.getState());

this.setState2(this.backup.getState2());

this.setState3(this.backup.getState3());

}

@Override

protected Originator clone() throws CloneNotSupportedException {

return (Originator) super.clone();

}

public String getState() {

return state;

}

public void setState(String state) {

this.state = state;

}

public String getState2() {

return state2;

}

public void setState2(String state2) {

this.state2 = state2;

}

public String getState3() {

return state3;

}

public void setState3(String state3) {

this.state3 = state3;

}

}

当然,我们知道通过clone的方式是有缺陷的,对象的复制都是浅拷贝,这样对于那些是对象类型的成员变量还是跟原来共享的不能完全的隔离。所以最好的方式应该是使用序列化(Serializable)来进行存储。

更安全的备忘录模式

作为备份的数据,是用作将来恢复系统使用的,所以必须保证数据的完整性、纯净性,不能随意被别人修改,否则就失去了作为备份的意义。那么我们就必须想办法不让别人能够去修改它,怎么做呢,这里可以备忘录通过实现一个标识接口(空接口)的办法来对外部进行隔离。示例代码:

public class Originator {

private String state;

/**

  • 创建备份

*/

public IMemento createMemento(){

return new Memento(state);

}

/**

  • 恢复备份

*/

public void restoreMemento(IMemento memento){

this.state = ((Memento) memento).getState();

}

public String getState() {

return state;

}

public void setState(String state) {

this.state = state;

System.out.println(“当前状态:” + this.state);

}

private class Memento implements IMemento {

private String state;

public Memento(String state){

this.state = state;

}

public String getState() {

return state;

}

public void setState(String state) {

this.state = state;

}

}

}

public interface IMemento {

}

public class Caretaker {

private IMemento memento;

/**

  • 获取备忘录

*/

public IMemento getMemento(){

return this.memento;

}

/**

  • 保存备忘录

*/

public void saveMemento(IMemento memento){

this.memento = memento;

}

}

可以看到我们的备忘录角色Memento现在是作为Originator的一个内部私有类,并且实现了IMemento接口,而IMemento接口是一个空接口,它什么方法也没有,Originator在创建和恢复备份的时候都是引用的IMemento接口类型,而在备忘录管理者Caretaker对备忘录的存取也都是通过IMemento接口类型,这样客户端在调用过程中能接触到的只有IMemento接口,而它不具有任何方法,所以就避免了别人去调用它的方法进行操作。

多重备份的备忘录模式

前面介绍的都是只有一份备份数据的情况,然而在实际当中很多情况下都是要做多重数据备份的,比如我今天发现系统异常,想要将系统数据恢复到昨天甚至前天或上个星期五的状态,这个时候我们就需要有多个备份数据提供选择。可以选择恢复多重备份的点叫做检查点(check point), 检查点就是一个标记,例如它可以是一个系统的时间戳等,每个检查点会对应一个备份数据以备后期选择性恢复。示例代码:

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

在这里小编整理了一份Android大厂常见面试题,和一些Android架构视频解析,都已整理成文档,全部都已打包好了,希望能够对大家有所帮助,在面试中能顺利通过。

image

image

喜欢本文的话,不妨顺手给我点个小赞、评论区留言或者转发支持一下呗

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

以扫码获取!!(备注:Android)**

最后

在这里小编整理了一份Android大厂常见面试题,和一些Android架构视频解析,都已整理成文档,全部都已打包好了,希望能够对大家有所帮助,在面试中能顺利通过。

[外链图片转存中…(img-2M0zyDaH-1713539325443)]

[外链图片转存中…(img-nFgjsmfU-1713539325444)]

喜欢本文的话,不妨顺手给我点个小赞、评论区留言或者转发支持一下呗

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值