zoukankan      html  css  js  c++  java
  • 命令模式

    今天做了命令模式的实验,用了差不多两个小时的时间,理解了命令模式的原理,下面是命令模式的实验要求和实现。

    实验要求:

    某系统需要提供一个命令集合(注:可以使用链表,栈等集合对象实现),用于存储一系列命令对象,并通过该命令集合实现多次undo()redo()操作,可以使用加法运算来模拟实现。

    类图:

     截图:

     代码:

    package 实验16命令模式;

    public abstract class AbstractCommand {
    public abstract int execute(int value);

    public abstract int undo();

    public abstract int redo();
    }

    package 实验16命令模式;

    import java.util.Stack;



    public class AddCommand extends AbstractCommand {
    private Adder adder = new Adder();
    private Stack<Integer> unStack = new Stack<Integer>();// 返回栈,用来记录所做的每一步操作,用于撤回
    private Stack<Integer> reStack = new Stack<Integer>();// 重复栈,用来存储返回栈弹出的数据,由于重复

    /**
    * 撤回
    */
    public int undo() {
    int i=0;
    if (unStack.isEmpty()) {

    i=-1;
    }else{
    Integer pop = unStack.pop();
    reStack.push(pop);
    if(!unStack.isEmpty()){//判断弹出数据后是否为空,如果为空,说明已撤回到最原始状态
    i=unStack.peek();
    }
    }
    return i;
    }

    /**
    * 恢复
    */
    public int redo() {
    int i=0;
    if (reStack.isEmpty()) {
    i=-1;
    }else{//撤回时只要可以可以撤回,则返回栈一定有数据
    Integer pop = reStack.pop();
    unStack.push(pop);
    i=pop;
    }
    return i;
    }

    /**
    * 执行计算,并进行栈的更新
    */
    public int execute(int value) {
    int v = 0;
    if (unStack.isEmpty()) {// 说明还没有数据
    v = adder.add(value);
    unStack.push(v);
    } else {// 需要更新两个栈中的内容,并计算结果,其中返回栈应该更新,重复栈应该清空
    v = adder.add(value);
    unStack.push(v);
    if (!reStack.isEmpty()) {
    for (int i = 0; i < reStack.size(); i++) {
    reStack.pop();
    }
    }
    }
    return v;
    }
    }

    package 实验16命令模式;

    public class Adder {
    private int num =0;
    public int add(int value) {
    num+=value;
    return num;
    }

    }

    package 实验16命令模式;

    public class CalculatorForm {
    private AbstractCommand command;
    public void setCommand(AbstractCommand command) {
    this.command =command;
    }
    /**
    * 执行运算
    * @param value
    */
    public void compute(int value) {
    command.execute(value);
    }
    /**
    * 撤回
    */
    public void undo() {
    int i = command.undo();
    if(i==-1){
    System.out.println("缓存中已不存在数据");
    }else{
    System.out.println("执行成功,运算结果是:"+i);
    }
    }
    /**
    * 恢复
    */
    public void redo() {
    int i = command.redo();
    if(i==-1){
    System.out.println("已恢复至最新数据");
    }
    else{
    System.out.println("执行成功,运算结果是:"+i);
    }
    }
    }

    package 实验16命令模式;

    public class client {
    public static void main(String[] args) {
    CalculatorForm form = new CalculatorForm();
    AddCommand command = new AddCommand();
    form.setCommand(command);
    //计算
    System.out.println("------计算过程-----");
    form.compute(1);
    form.compute(2);
    form.compute(3);
    form.compute(4);
    //多次撤回
    System.out.println("------撤回过程-----");
    form.undo();
    form.undo();
    form.undo();
    form.undo();
    form.undo();
    //多次恢复
    System.out.println("------恢复过程-----");
    form.redo();
    form.redo();
    form.redo();
    form.redo();
    form.redo();
    }
    }

  • 相关阅读:
    POJ 2661
    POJ 2643
    POJ 2656
    POJ 2612
    POJ 2636
    搭建WordPress个人博客
    【个人笔记】ximo早期发的脱壳教程——手脱UPX壳
    2.1【欢乐向】攻防世界新手逆向刷题被虐哭日常记录
    吾爱破解培训第一课个人笔记
    第五章 计算机组成
  • 原文地址:https://www.cnblogs.com/092e/p/15529974.html
Copyright © 2011-2022 走看看