Java使用备忘录模式实现过关类游戏功能详解

本文实例讲述了Java使用备忘录模式实现过关类游戏功能。分享给大家供大家参考,具体如下:

一.模式定义

备忘录模式,在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象外部保存这个状态。这样以后就可将该对象恢复到原先保存的状态。

二.模式举例

1模式分析

我们借用过关类游戏来说明这一模式。

2备忘录模式静态类图

3代码示例(黑箱备忘录模式)

3.1创建备忘录窄接口一INarrowMemento

package com.demo.memento;
/**
 * 备忘录窄接口(不提供任何方法,外部对象不能访问备忘录对象内部信息)
 *
 * @author
 *
 */
public interface INarrowMemento {
}

3.2备忘录发起者一Hero

package com.demo.originator;
import java.util.Random;
import com.demo.memento.INarrowMemento;
/**
 * 挑战者
 *
 * @author
 *
 */
public class Hero {
  // 血液值
  private int blood;
  // 武力值
  private int sword;
  // 随机数
  private final Random random = new Random();
  // 构造方法初始化 内容
  public Hero() {
    this.blood = 100;
    this.sword = 100;
  }
  // 创建备忘录保存内容
  public INarrowMemento createMemento() {
    System.out.println("创建备忘录...");
    return new Memento(this.blood, this.sword);
  }
  // 恢复备忘录内容
  public void restoreFromMemento(INarrowMemento memento) {
    System.out.println("恢复备忘录中的状态...");
    if (memento != null) {
      Memento memento2 = (Memento) memento;
      this.blood = memento2.getBlood();
      this.sword = memento2.getSword();
    }
  }
  /**
   * 挑战BOSS
   */
  public int koBoss() {
    // 当血液值<=0 时 挑战失败 假设战胜BOSS的概率为2%
    // 判断时候还有血液值
    if (this.blood <= 0 || this.sword <= 0) {
      System.out.println(this.toString());
      System.out.println("挑战BOSS失败!");
      return -1;
    } else {
      // 获得随机数
      double win = Math.random();
      if (win <= 0.02) {
        System.out.println(this.toString());
        System.out.println("恭喜你,挑战BOSS成功!");
        return 1;
      } else {
        System.out.println(this.toString());
        System.out.println("继续攻击BOSS...");
        // 随机数减少血液值和武力值 继续KO
        int blood_sub = random.nextInt(10);
        int sword_sub = random.nextInt(10);
        this.blood -= blood_sub;
        this.sword -= sword_sub;
        return 0;
      }
    }
  }
  @Override
  public String toString() {
    return "当前血液值:" + this.blood + " - 当前武力值:" + this.sword;
  }
  /**
   * 备忘录(整个类都是私有的,只有发起者才能访问)
   *
   * @author
   *
   */
  private class Memento implements INarrowMemento {
    // 血液值
    private final int blood;
    // 武力值
    private final int sword;
    // 构造方法初始化 内容
    private Memento(int blood, int sword) {
      this.blood = blood;
      this.sword = sword;
    }
    private int getBlood() {
      return blood;
    }
    private int getSword() {
      return sword;
    }
  }
}

3.3备忘录管理者一Caretaker

package com.demo.caretaker;
import com.demo.memento.INarrowMemento;
/**
 * 管理者
 *
 * @author
 *
 */
public class Caretaker {
  private INarrowMemento memento;
  /**
   * 获得备忘录对象
   *
   * @return
   */
  public INarrowMemento getMemento() {
    return memento;
  }
  /**
   * 保存备忘录对象
   *
   * @param memento
   */
  public void setMemento(INarrowMemento memento) {
    this.memento = memento;
  }
}

3.4让英雄挑战Boss一Client

package com.demo;
import com.demo.caretaker.Caretaker;
import com.demo.originator.Hero;
/**
 * 客户端主应用程序
 *
 * @author
 *
 */
public class Client {
  /**
   * @param args
   */
  public static void main(String[] args) {
    // 创建角色
    Hero hero = new Hero();
    // 创建管理者
    Caretaker caretaker = new Caretaker();
    // 保存挑战前的状态信息
    caretaker.setMemento(hero.createMemento());
    // 只有三次战胜BOSS的机会
    int cnt = 1;
    // 挑战BOSS结果
    int ko = -1;
    while (ko != 1 && cnt <= 3) {
      System.out
          .println("=============== 第" + cnt + "次挑战 ==============");
      // 开始挑战BOSS
      ko = hero.koBoss();
      while (true) {
        if (ko == -1) {
          // 挑战失败 恢复到初始状态 累加挑战次数
          hero.restoreFromMemento(caretaker.getMemento());
          cnt += 1;
          break;
        } else if (ko == 0) {
          // 继续挑战
          ko = hero.koBoss();
        } else if (ko == 1) {
          // 挑战成功!
          break;
        }
      }
    }
  }
}

4运行结果

创建备忘录...
=============== 第1次挑战 ==============
当前血液值:100 - 当前武力值:100
继续攻击BOSS...
当前血液值:96 - 当前武力值:99
继续攻击BOSS...
当前血液值:90 - 当前武力值:98
继续攻击BOSS...
当前血液值:81 - 当前武力值:95
继续攻击BOSS...
当前血液值:78 - 当前武力值:93
继续攻击BOSS...
当前血液值:72 - 当前武力值:88
继续攻击BOSS...
当前血液值:64 - 当前武力值:85
继续攻击BOSS...
当前血液值:56 - 当前武力值:80
继续攻击BOSS...
当前血液值:49 - 当前武力值:73
继续攻击BOSS...
当前血液值:45 - 当前武力值:71
继续攻击BOSS...
当前血液值:37 - 当前武力值:68
继续攻击BOSS...
当前血液值:29 - 当前武力值:65
继续攻击BOSS...
当前血液值:20 - 当前武力值:59
继续攻击BOSS...
当前血液值:11 - 当前武力值:54
继续攻击BOSS...
当前血液值:9 - 当前武力值:52
继续攻击BOSS...
当前血液值:3 - 当前武力值:45
继续攻击BOSS...
当前血液值:-3 - 当前武力值:41
挑战BOSS失败!
恢复备忘录中的状态...
=============== 第2次挑战 ==============
当前血液值:100 - 当前武力值:100
继续攻击BOSS...
当前血液值:96 - 当前武力值:95
继续攻击BOSS...
当前血液值:96 - 当前武力值:91
继续攻击BOSS...
当前血液值:88 - 当前武力值:82
继续攻击BOSS...
当前血液值:79 - 当前武力值:79
继续攻击BOSS...
当前血液值:76 - 当前武力值:72
继续攻击BOSS...
当前血液值:73 - 当前武力值:70
继续攻击BOSS...
当前血液值:72 - 当前武力值:66
继续攻击BOSS...
当前血液值:72 - 当前武力值:61
继续攻击BOSS...
当前血液值:72 - 当前武力值:58
继续攻击BOSS...
当前血液值:72 - 当前武力值:52
继续攻击BOSS...
当前血液值:63 - 当前武力值:51
继续攻击BOSS...
当前血液值:62 - 当前武力值:50
继续攻击BOSS...
当前血液值:54 - 当前武力值:41
继续攻击BOSS...
当前血液值:50 - 当前武力值:39
继续攻击BOSS...
当前血液值:47 - 当前武力值:39
继续攻击BOSS...
当前血液值:43 - 当前武力值:38
继续攻击BOSS...
当前血液值:37 - 当前武力值:36
继续攻击BOSS...
当前血液值:34 - 当前武力值:35
继续攻击BOSS...
当前血液值:32 - 当前武力值:27
继续攻击BOSS...
当前血液值:28 - 当前武力值:22
继续攻击BOSS...
当前血液值:26 - 当前武力值:15
继续攻击BOSS...
当前血液值:24 - 当前武力值:11
继续攻击BOSS...
当前血液值:19 - 当前武力值:3
继续攻击BOSS...
当前血液值:10 - 当前武力值:-3
挑战BOSS失败!
恢复备忘录中的状态...
=============== 第3次挑战 ==============
当前血液值:100 - 当前武力值:100
继续攻击BOSS...
当前血液值:99 - 当前武力值:93
继续攻击BOSS...
当前血液值:98 - 当前武力值:84
继续攻击BOSS...
当前血液值:98 - 当前武力值:82
继续攻击BOSS...
当前血液值:95 - 当前武力值:76
继续攻击BOSS...
当前血液值:88 - 当前武力值:68
继续攻击BOSS...
当前血液值:81 - 当前武力值:64
继续攻击BOSS...
当前血液值:76 - 当前武力值:64
继续攻击BOSS...
当前血液值:67 - 当前武力值:64
恭喜你,挑战BOSS成功!

三. 该模式设计原则

1封装边界的保持
2双重接口实现,保证安全性。

四. 使用场合

1需要在某一时刻恢复一个对象先前的状态时。
2白箱备忘录模式,需要在外部保存对象某一时刻的状态,但如果用一个接口来让其他对象直接得到这些状态,将会暴露对象的实现细节并破坏对象的封装性。
3黑箱备忘录模式实现方式提供了双重接口访问机制,对发起者对象提供宽接口,而对发起者以外的对象提供窄接口,从而有效解决了封装性和安全性。

五. 静态类图

1白箱备忘录模式静态类图

2黑箱备忘录模式静态类图

更多java相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。

您可能感兴趣的文章:

  • Java策略模式的简单应用实现方法
  • 对比Java设计模式编程中的状态模式和策略模式
  • Java设计模式之策略模式(Strategy模式)介绍
  • Java基于状态模式实现的文档编辑模式切换功能实例
  • Java使用观察者模式实现气象局高温预警功能示例
  • Java使用访问者模式解决公司层级结构图问题详解
  • Java基于代理模式解决红酒经销问题详解
  • Java基于命令模式实现邮局发信功能详解
  • Java使用责任链模式处理学生请假问题详解
  • Java使用策略模式解决商场促销商品问题示例
(0)

相关推荐

  • Java使用责任链模式处理学生请假问题详解

    本文实例讲述了Java使用责任链模式处理学生请假问题.分享给大家供大家参考,具体如下: 一. 模式定义 在责任链模式中,很多对象由每一个对象对其下家的引用而连接起来,形成一条链.客户端应用请求在这个链上进行传递,直到链上的某一个对象决定处理此请求.发出这个请求的客户端并不知道链上的哪个对象最终处理这个请求,这使系统可以在不影响客户端的情况下动态地重新组织链和分配责任. (1)抽象处理者角色:定义出一个处理请求的接口.如果需要,接口可以定义出一个方法,以设定和返回下家的引用.这个角色通常由一个Ja

  • Java设计模式之策略模式(Strategy模式)介绍

    Strategy是属于设计模式中 对象行为型模式,主要是定义一系列的算法,把这些算法一个个封装成单独的类. Stratrgy应用比较广泛,比如,公司经营业务变化图,可能有两种实现方式,一个是线条曲线,一个是框图(bar),这是两种算法,可以使用Strategy实现. 这里以字符串替代为例,有一个文件,我们需要读取后,希望替代其中相应的变量,然后输出.关于替代其中变量的方法可能有多种方法,这取决于用户的要求,所以我们要准备几套变量字符替代方案. 首先,我们建立一个抽象类RepTempRule 定义

  • Java基于命令模式实现邮局发信功能详解

    本文实例讲述了Java基于命令模式实现邮局发信功能.分享给大家供大家参考,具体如下: 一. 模式定义 命令模式,将来自客户端的请求封建为一个对象,无须了解这个请求激活的动作或有关接受这个请求的处理细节.命令模式的根本目的在于将"请求者"与"实现者"之间解耦. 二. 模式举例 1 模式分析 我们借用邮局发信来说明这一模式. 2 命令模式静态类图 3 代码示例 3.1信件接收者接口一IReceiver package com.demo.receiver; /** * 信

  • Java基于状态模式实现的文档编辑模式切换功能实例

    本文实例讲述了Java基于状态模式实现的文档编辑模式切换功能.分享给大家供大家参考,具体如下: 一 模式定义 状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象看起来就像是改变了其类. 二 模式举例 1 模式分析 我们借用文档编辑模式切换这一案例来说明这一模式. 2 状态模式静态类图 3 代码示例 3.1 创建状态接口一IState package com.demo.state; import com.demo.context.Context; /** * * 状态接口 * * @au

  • Java使用访问者模式解决公司层级结构图问题详解

    本文实例讲述了Java使用访问者模式解决公司层级结构图问题.分享给大家供大家参考,具体如下: 一. 模式定义 访问者模式:是表示一个作用于某对象结构中各个元素的操作,它使用户可以在不改变各元素类的前提下定义作用于这些元素的新操作. 二. 模式举例 1 模式分析 我们借用公司层级结构来说明这一模式. 2 访问者模式静态类图 3 代码示例 3.1 抽象员工一Staff package com.demo.structure; import com.demo.visitor.IVisitor; /**

  • Java使用观察者模式实现气象局高温预警功能示例

    本文实例讲述了Java使用观察者模式实现气象局高温预警功能.分享给大家供大家参考,具体如下: 一.模式定义 观察者模式,又称为发布/订阅模式.观察者模式定义了对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新. 二.模式举例 1 模式分析 我们借用气象局高温预警来说明这一模式. 2 观察者模式静态类图 3 代码示例 3.1观察者接口一IObserver package com.demo.observer; import com.demo.subje

  • 对比Java设计模式编程中的状态模式和策略模式

    为了能在Java应用程序中正确的使用状态模式和策略模式,开发人员需要清楚地知道这两种模式之间的区别.尽管状态模式和策略模式的结构非常相似,它们又同样遵循开闭原则,都代表着SOLID设计原则的'O',但它们的意图是完全不同的.Java中的策略模式是对一组相关的算法进行封装,给调用方提供了运行时的灵活性.调用方可以在运行时选择不同的算法,而不用修改使用策略的那个Context类.使用策略模式的经典例子包括实现加密算法,压缩算法,以及排序算法.另一方面,状态模式使用一个对象可以在不同的状态下表现出不同

  • Java策略模式的简单应用实现方法

    在使用图像处理软件处理图片后,需要选择一种格式进行保存.然而各种格式在底层实现的算法并不相同,这刚好适合策略模式.编写程序,演示如何使用策略模式与简单工厂模式组合进行开发. 思路如下: 1.使用interface来定义一个接口,在该接口中定义save()方法:2.根据图片格式定义不同的类,分别在这些类中使用关键字implements实现接口:3.创建一个实现选择的类,在该类中定义实现选择的方法,该方法返回值为对应的图片保存类:4.在主方法中实现接口.代码如下: 复制代码 代码如下: public

  • Java基于代理模式解决红酒经销问题详解

    本文实例讲述了Java基于代理模式解决红酒经销问题.分享给大家供大家参考,具体如下: 一. 模式定义 在代理模式中,有两个对象参与处理同一请求,接收的请求由代理对象委托给真实对象处理,代理对象控制请求的访问,它在客户端应用程序与真实对象之间起到了一个中介桥梁的作用.代理模式使用对象聚合代替继承,有效地降低了软件模块之间的耦合度. 二. 模式举例 1 模式分析 我们借用红酒经销来说明这一模式. 2 代理模式静态类图 3 代码示例 3.1 红酒工厂接口一IRedWine package com.de

  • Java使用策略模式解决商场促销商品问题示例

    本文实例讲述了Java使用策略模式解决商场促销商品问题.分享给大家供大家参考,具体如下: 一 模式定义 策略模式:定义一系列的算法,将每一种算法封装起来并可以相互替换使用,策略模式让算法独立于使用它的客户应用而独立变化. 二 模式举例 1 模式分析 我们借用商场促销商品来说明这一模式. 2 策略模式静态类图 3 代码示例 3.1 创建策略接口一IStrategy package com.demo.strategy; /** * 策略接口 * * @author * */ public inter

随机推荐