首页 > 其他分享 >每日总结-23.11.19

每日总结-23.11.19

时间:2023-11-20 09:24:08浏览次数:38  
标签:总结 23.11 form 19 undo unStack int redo public

import java.util.Stack;
public abstract class AbstractCommand {
    public abstract int execute(int value);
    public abstract int undo();
    public abstract int redo();
}
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;
    }
}
public class Adder {
    private int num =0;
    public int add(int value) {
        num+=value;
        return num;
    }
}
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);
        }
    }
}
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();
    }
}

 

标签:总结,23.11,form,19,undo,unStack,int,redo,public
From: https://www.cnblogs.com/laobing6214/p/17843184.html

相关文章

  • 每日总结-23.11.20
    publicclassMemory{privatestaticMemoryinstance=newMemory();publicstaticMemorygetInstance(){returninstance;}publicbooleancheck(booleanoperIf){System.out.println("内存开始自检");if(ope......
  • 20231109学习总结
    MySQL重新初始化1.需要将mysql数据目录下的数据全部清空rm-rf/data/mysql/data 2.初始化数据库/usr/local/mysql/bin/mysqld   --initialize--user=mysql--basedir=/usr/local/mysql--datadir=/data/mysql/data/ 3.重新启动数据库 /etc/init.d/mysqldst......
  • 20231120学习总结.
    信1305班共44名同学,每名同学都有姓名,学号和年龄等属性,分别使用JAVA内置迭代器和C++中标准模板库(STL)实现对同学信息的遍历,要求按照学号从小到大和从大到小两种次序输出学生信息。Java:publicinterfaceAggregate{publicvoidadd(Objectobj);publicvoidremove(Ob......
  • 2023-2024-1 20231413 《计算机基础与程序设计》第八周学习总结
    2023-2024-120231413《计算机基础与程序设计》第八周学习总结1.作业信息班级:2023-2024-1-计算机基础与程序设计作业要求:2023-2024-1《计算机基础与程序设计》教学进程目标:自学教材:计算机科学概论第9章并完成云班课测试《C语言程序设计》第7章并完成云班课测试作业正文:h......
  • BLOG总结
    前言:    在过去的三个星期里,我接触了许多新的知识和技能。从编程思想到软件包的使用,涉及了诸如set、map、stream、DoubleLinkedList、lambda表达式、正则表达式等内容,这些是我之前接触较少但非常精密的知识。同时,我还学习了银行类的设计、农夫过河实验以及期中考试(主要考......
  • 2023-2024-1 20231427 《计算机基础与程序设计》第八周学习总结
    作业信息这个作业属于哪个课程<班级的链接>(https://www.cnblogs.com/rocedu/p/9577842.html#JXJC)这个作业要求在哪里<作业要求的链接>(https://www.cnblogs.com/rocedu/p/9577842.html#WEEK08)|作业正文|...https://www.cnblogs.com/wszdhnsh/p/17842926.html |......
  • 11.19(函数)
    函数是什么?1.函数就是一个大型程序中某部分代码,由一个或多个模块组成。相较于其他代码,有一定的独立性。2.一般函数都有独立信函数的分类:a:函数库:C语言本身提供的函数b:自定义函数:体现的解决问题的能力函数的调用:传值调用  传址调用#include<stdio.h>#include<math.h>intis_p......
  • 219-nginx 配置https,证书配置
    server{#SSL默认访问端口号为443listen443ssl;#请填写绑定证书的域名server_nameqzkuma.cn;#请填写证书文件的相对路径或绝对路径ssl_certificate/home/ssl/qzkuma.cn_bundle.crt;#请填写私钥文件的相对路径或绝对路径s......
  • 2023.11.19 NOIP 总结
    考试复盘进场读了下题,T1很简单,并且后面三道题都挺可做的。因为可以任意交换,直接令当前串字典序最小,其它串字典序最大,然后比较一下就完事了。因为字符集大小只有\(26\),直接开桶模拟就可以了。发现不是很好写,想了一下其实只需要判断一下当前串字典序最小的字母的字典序是否大于其......
  • 2023-2024-1 20231305 《计算机基础与程序设计》第八周学习总结
    2023-2024-120231305《计算机基础与程序设计》第八周学习总结作业信息这个作业属于哪个课程<班级的链接>(如2022-2023-1-计算机基础与程序设计)这个作业要求在哪里<作业要求的链接>(如2022-2023-1计算机基础与程序设计第一周作业)这个作业的目标<写上具体方面>......