命令模式——java实现

问题描述:

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

类图:

 

 代码:

//Invoker.java
package shiyan16;

public class Invoker {
    private Command command;
    public void setCommand(Command command) {
        this.command =command;
    }
    /**
     * 执行运算
     * @param value
     */
    public void addNum(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);
        }
    }
}
//Command.java
package shiyan16;

public abstract class Command {
      public abstract int execute(int value);
      public abstract int undo();
      public abstract int redo();
}
//Adder.java
package shiyan16;

public class Adder {
     private int num =0;
     public int addOperate(int value) {
         num+=value;
         return num;
     }
}
//AddCommand.java
package shiyan16;

import java.util.Stack;

public class AddCommand extends Command{
     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;
         v = adder.addOperate(value);
         System.out.println(v);
         unStack.push(v);
         return v;
     }
}
//Client.java
package shiyan16;
public class Client {
    public static void main(String[] args) {
        Invoker inv = new Invoker();
        AddCommand command = new AddCommand();
        inv.setCommand(command);
        //计算
        System.out.println("计算过程:");
        inv.addNum(1);
        inv.addNum(2);
        inv.addNum(3);
        //多次撤回
        System.out.println("undo操作:");
        inv.undo();
        inv.undo();
        inv.undo();
        inv.undo();
        //多次恢复
        System.out.println("redo操作:");
        inv.redo();
        inv.redo();
        inv.redo();
        inv.redo();
    }
}

  运行截图:

 

posted @ 2022-11-13 22:01  好(justice)……  阅读(63)  评论(0编辑  收藏  举报