首页 > 其他分享 >实验16:命令模式

实验16:命令模式

时间:2023-12-09 20:44:07浏览次数:34  
标签:16 int inv 模式 实验 undo command redo public

本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 

1、理解命令模式的动机,掌握该模式的结构;

2、能够利用命令模式解决实际问题。

 

[实验任务一]:多次撤销和重复的命令模式

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

 

实验要求:

1. 提交类图;

2. 提交源代码;

3. 注意编程规范。

//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();

    }

}

标签:16,int,inv,模式,实验,undo,command,redo,public
From: https://www.cnblogs.com/lin513/p/17891458.html

相关文章

  • 实验14:代理模式
    [实验任务一]:婚介所婚介所其实就是找对象的一个代理,请仿照我们的课堂例子“论坛权限控制代理”完成这个实际问题,其中如果年纪小于18周岁,婚介所会提示“对不起,不能早恋!”,并终止业务。实验要求:1. 提交类图;、2.提交源代码;3.注意编程规范。packageorg.example;publicclas......
  • Python - 实现【单例模式】的四种方法
    方法一:使用模块实现单例模式在Python中,每个模块只会被导入一次,因此可以将需要实现单例模式的类定义在一个模块中,每次需要使用该类时,将该模块导入即可。#singleton.pyclassSingleton:passsingleton=Singleton()在其他模块中直接引用这个singleton对象即可。2.方法二:使......
  • CF1672F1
    我们知道要是任意位置交换就是环长-1那我们肯定要让环尽量少即可那我们的环最多就是出现最多的那个数字的次数构造策略就是把其他不同的数字都提出来然后往后挪一下就可以构造出环了voidsolve(){intn;cin>>n;vector<int>a(n+1),v[n+1];for(inti=1;i<=n......
  • 23种设计模式——适配器模式
    今天开始我们就要进入到结构型的设计模式学习之中了,今天讲的设计模式是23种设计模式的第六种——适配器模式。通俗的讲,适配器的作用就是将两个互不兼容的东西进行一个适配的操作,它作为中间的桥梁。下面我们进入适配器模式的学习。应用前景:在现实生活中,适配器这样的例子随处可......
  • flask支持Vue2 mode history历史模式
    VueRouter配置在Vue2router里面增加constrouter=newVueRouter({mode:'history',base:'/admin/',//这里路径写你打包后的网址路径routes:[//这里是你的路由配置],});vue.config.js打包配置const{defineConfig}=require('@vue/cli-service......
  • 「杂题乱刷」洛谷P1216
    题目链接一道dp的入门题。\(O(2^n)\):考虑直接爆搜,可以考虑到所有情况。\(O(n^2)\):考虑\(dp\),设\(dp_{i,j}\)代表到达第\(i\)层第\(j\)个数所能达到的最大值。状态转移方程为\(dp_{i,j}=a_{i,j}+\max(dp_{i-1,j-1},dp_{i-1,j})\)。最终答案就是\(\max(dp_{n,1},d......
  • Java-Spring框架中用到的设计模式
    Java-Spring框架中用到的设计模式单例模式(Singleton)Spring中的Bean默认是单例的,容器中只存在一个实例。这有助于节省资源,提高性能。工厂模式(Factory)Spring使用工厂模式来创建和管理Bean。通过配置文件或注解,Spring容器可以根据需要创建相应的Bean对象。代理模......
  • 【单片机】实验七:定时计数器实验
    #include<STC8.H>/*#定时计数器溢出发生中断原理实验@2023N12Y7R#P1:控制显示内容#P2:控制显示位置实验目的:利用单片机内部定时器T0或者T1,控制一个LED数码管实现数字0-9循环显示,精确执行每一秒显示一个数字*/unsignedcharled[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7......
  • [ARC164E] Segment-Tree Optimization 题解
    题目链接题目链接题目解法一个自认为比较自然的解法这种一段序列切成两部分的问题首先考虑区间\(dp\)令\(f_{l,r}\)为\([l,r]\)能构成的最小深度,\(g_{l,r}\)为在\(f_{l,r}\)最小的情况下最少的最大深度的点的个数转移枚举\(k\)即可需要在下面是叶子的时候处理一......
  • 单例设计模式
    单例模式是一种常用的软件设计模式,其目标是确保一个类只有一个实例,并提供一个全局访问点。在C++中,可以通过以下步骤实现单例模式:私有化构造函数,以防止外界创建单例类的对象。使用类的私有静态指针变量指向类的唯一实例。使用一个公有的静态方法获取该实例。以下是一个简......