【梦辛工作室】IF判断优化、责任链模式 IfChain

大家好哇,我是梦辛工作室的灵,在最近的开发中,有许多需要判断的分支处理,且处理内容较多且复杂,代码就容易越写越复杂,导致后期无法继续更新跌打,然后基于这个环境,我用责任链模式写了一个工具类用于解决这个问题,并将数据、判断、处理分隔开来,这样代码的重用性也增强了,下面来看下使用效果:
在这里插入图片描述
使用方法如下:
在这里插入图片描述
这里可自定义判断器和处理器,并自由组合,并链接起来,这里的判读器需实现一个检查方法,返回true 才会执行Handler的hand 方法,
而处理器返回true的话,就表示不在继续往后判断了,返回false表示,代码还是会下一个判断器进行判断

 class  Data1Check implements IfCheck{
        @Override
        public boolean check(Object[] args) {
            if(args != null && args.length > 0 && "data1".equals(args[0])){
                System.out.println("Data1Check==>" + args[0] + "检查成功,处理");
                return true;
            }
            System.out.println("Data1Check==>" +  args[0] + "检查失败,不处理");
            return false;
        }
    }

    class Data1Handler implements IfHandler{

        @Override
        public boolean hand(Object[] args) {
            System.out.print(args[0]);
            System.out.println("已被Data1Handler处理");
            return false;
        }
    }

    class  Data2Check implements IfCheck{
        @Override
        public boolean check(Object[] args) {
            if(args != null && args.length > 0 && "data2".equals(args[0])){
                System.out.println("Data2Check==>" + args[0] + "检查成功,处理");
                return true;
            }
            System.out.println("Data2Check==>" + args[0] + "检查失败,不处理");
            return false;
        }
    }

    class Data2Handler implements IfHandler{

        @Override
        public boolean hand(Object[] args) {
            System.out.print(args[0]);
            System.out.println("已被Data2Handler处理");
            return true;
        }
    }

然后再来看下完整的代码:
IfChain

public class IfChain {
    private IfChain nextChain;
    private Object[] args;

    private IfHandler handler;

    private IfCheck ifCheck;

    public IfChain(IfCheck ifCheck,IfHandler handler){
        this.ifCheck = ifCheck;
        this.handler = handler;
    }

    private boolean check(){
        if (ifCheck.check(args)){
            return handler.hand(args);
        }
        return false;
    }

    public IfCheck getIfCheck() {
        return ifCheck;
    }

    public void setIfCheck(IfCheck ifCheck) {
        this.ifCheck = ifCheck;
    }

    public IfChain getNextChain() {
        return nextChain;
    }

    public void setNextChain(IfChain nextChain) {
        this.nextChain = nextChain;
    }

    public Object[] getArgs() {
        return args;
    }

    public void setArgs(Object[] args) {
        this.args = args;
    }

    public IfHandler getHandler() {
        return handler;
    }

    public void setHandler(IfHandler handler) {
        this.handler = handler;
    }

    public void startCheck(){
        if (!check() && nextChain != null){
            nextChain.setArgs(args);
            nextChain.startCheck();
        }
    }

}

IfHandler

public interface IfHandler {
    boolean hand(Object[] args);
}

IfCheck

public interface IfCheck {
    boolean check(Object[] args);
}

TestIfChain


public class TestIfChain {


    class  Data1Check implements IfCheck{
        @Override
        public boolean check(Object[] args) {
            if(args != null && args.length > 0 && "data1".equals(args[0])){
                System.out.println("Data1Check==>" + args[0] + "检查成功,处理");
                return true;
            }
            System.out.println("Data1Check==>" +  args[0] + "检查失败,不处理");
            return false;
        }
    }

    class Data1Handler implements IfHandler{

        @Override
        public boolean hand(Object[] args) {
            System.out.print(args[0]);
            System.out.println("已被Data1Handler处理");
            return false;
        }
    }

    class  Data2Check implements IfCheck{
        @Override
        public boolean check(Object[] args) {
            if(args != null && args.length > 0 && "data2".equals(args[0])){
                System.out.println("Data2Check==>" + args[0] + "检查成功,处理");
                return true;
            }
            System.out.println("Data2Check==>" + args[0] + "检查失败,不处理");
            return false;
        }
    }

    class Data2Handler implements IfHandler{

        @Override
        public boolean hand(Object[] args) {
            System.out.print(args[0]);
            System.out.println("已被Data2Handler处理");
            return true;
        }
    }

    @Test
    public void doTest(){

        doCheck("data1");

        doCheck("data2");

        doCheck("data3");

    }

    private void doCheck(String data) {

        Object[] args = new Object[]{data};

        IfChain ifChainData1 = new IfChain(new Data1Check(),new Data1Handler());

        ifChainData1.setArgs(args);

        IfChain ifChainData2 = new IfChain(new Data2Check(),new Data2Handler());

        ifChainData2.setArgs(args);

        ifChainData1.setNextChain(ifChainData2);

        ifChainData1.startCheck();
    }

    private void doCheck2(String data){
        if("data1".equals(data)){
            System.out.println("data1已被Data1Handler");
            return;
        }
        if("data2".equals(data)){
            System.out.println("data1已被Data2Handler");
            return;
        }
    }
}

好了,今天的分享就到这里了
github连接 https://github.com/wintton/MxTestSql.git

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/44896.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

leetcode 面试题 判定是否互为字符重排

⭐️ 题目描述 🌟 leetcode链接:判定是否互为字符重排 思路: 两个字符串的每个字母和数量都相等。那么 s2 一定可以排成 s1 字符串。 代码: bool CheckPermutation(char* s1, char* s2){char hash1[26] {0};char hash2[26] {…

【ICCV2023】Scale-Aware Modulation Meet Transformer

Scale-Aware Modulation Meet Transformer, ICCV2023 论文:https://arxiv.org/abs/2307.08579 代码:https://github.com/AFeng-x/SMT 解读:ICCV2023 | 当尺度感知调制遇上Transformer,会碰撞出怎样的火花&#xff1…

三,创建订单微服务消费者 第三章

4.3 修改pom添加依赖 <dependencies><!--web--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--监控--><dependency><groupId&g…

Windows安装postgresql时,启动报1053错误

用SQL shell 连接时显示拒绝连接&#xff0c;是因为postgreSql没有启动。 点击“服务”启动却报 1053错误 点击postgreSql服务&#xff0c;选择 登录-》选择本地系统账户&#xff0c;方可启动服务

网络安全 Day19-计算机网络基础知识04(网络协议)

计算机网络基础知识04&#xff08;网络协议&#xff09; 1. ARP1.1 ARP通讯原理1.2 arp欺骗1.3 ARP欺骗与预防1.4 排查ARP病毒 2. DHCP工作原理&#xff08;自动分配内网IP&#xff09;3. TCP协议三次握手、四次挥手原理4. DNS协议工作原理 1. ARP Linux查看arp&#xff1a;ar…

Mysql错误日志、通用查询日志、二进制日志和慢日志的介绍和查看

一.日志 1.日志和备份的必要性 日志刷新 2.mysql的日志类型 &#xff08;1&#xff09;错误日志 查看当前错误日志和是否记录警告设置 &#xff08;2&#xff09;通用查询日志 查看通用查询日志的设置 &#xff08;3&#xff09;二进制日志 查看二进制文件的设置&…

Hadoop 之 Hbase 配置与使用(四)

Hadoop 之 Hbase 配置与使用 一.Hbase 下载1.Hbase 下载 二.Hbase 配置1.单机部署2.伪集群部署&#xff08;基于单机配置&#xff09;3.集群部署1.启动 hadoop 集群2.启动 zookeeper 集群3.启动 hbase 集群4.集群启停脚本 三.测试1.Pom 配置2.Yml 配置3.Hbase 配置类4.Hbase 连…

关于PyTorch中一维卷积Conv1d的理解

首先明确一点&#xff0c;PyTorch中的一维卷积是从左往右做的&#xff0c;不是从上往下。 然后明确第二点&#xff0c;一维卷积和二维卷积最大的区别在于&#xff0c;一维卷积的卷积方向只有一个维度&#xff0c;一维卷积的卷积核不像二维卷积核一样可以左右和上下两个维度移动…

【使用时空RBF-NN进行非线性系统识别】实现了 RBF、分数 RBF 和时空 RBF 神经网络,用于非线性系统识别研究(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 2.1 算例1 2.2 算例2 &#x1f389;3 参考文献 &#x1f308;4 Matlab代码实现 &#x1f4a5;1 概述 本文用于非线性系统识别任务的径向基函数神经网络&#xff08;RBF-NN&#xff09;的三种变体。特别是&#xff0c;我实现…

大模型,开源干不掉闭源

开源大模型对闭源大模型的冲击&#xff0c;变得非常猛烈。 今年3月&#xff0c;Meta发布了Llama&#xff08;羊驼&#xff09;&#xff0c;很快成为AI社区内最强大的开源大模型&#xff0c;也是许多模型的基座模型。有人戏称&#xff0c;当前的大模型集群&#xff0c;就是一堆各…

刘铁猛C#教程笔记——操作符

C#语言中的操作符 表中位于同一行的操作符优先级相同&#xff0c;从上到下优先级依次减弱&#xff1b; 操作符的用法举例 成员访问运算符——“.”&#xff1a;用于访问类中的成员或者访问位于某个名空间中的类&#xff0c;如&#xff1a; using System; using System.Collec…

25.3 matlab里面的10中优化方法介绍——Nelder-Mead法(matlab程序)

1.简述 fminsearch函数用来求解多维无约束的线性优化问题 用derivative-free的方法找到多变量无约束函数的最小值 语法 x fminsearch(fun,x0) x fminsearch(fun,x0,options) [x,fval] fminsearch(...) [x,fval,exitflag] fminsearch(...) [x,fval,exitflag,output] fmins…

使用sftp

一、背景 新项目组前端部署方式是Build打包生成dist文件&#xff0c;交由后端部署。后来知道了vscode安装sftp前端可以自行部署。 二、实操 1、vscode安装sftp 2、 配置 ①F1 / ctrlshiftp ②命令行输入sftp -> 选择 sftp: Config ③配置信息介绍 {"name"…

vscode默认gbk编码格式打开

目录 1. 问题描述2. 解决方案 1. 问题描述 每次打开vscode都是utf-8格式打开文件&#xff0c;然后满屏的中文乱码&#xff0c;自己手动换成gbk编码 后中文显示正常&#xff0c;但是换多了很烦。 2. 解决方案 ctrlshiftP 点首选项&#xff1a;打开用户设置 加上这行在最后&…

SpringBoot静态资源访问及参数处理

静态资源访问&#xff1a; 资源访问&#xff1a; 1&#xff1a;Spring Boot 支持静态和模板化的欢迎页面。它首先在配置的静态内容位置中查找index.html文件。如果未找到&#xff0c;则查找index相关模板。如果找到任一&#xff0c;它将自动用作应用程序的欢迎页面。 2&…

Elasticsearch笔记

一、ElasticSearch概述 ElasticSearch&#xff08;简称ES&#xff09;是一个分布式、RESTful 风格的搜索引擎、数据分析引擎。ES底层是基于Apache Lucene搜索引擎库实现的&#xff0c;但是ES的目的是通过简单的RESTful API来隐藏Lucene的复杂性&#xff0c;从而让全文搜索变得简…

Redisson实现简单消息队列:优雅解决缓存清理冲突

在项目中&#xff0c;缓存是提高应用性能和响应速度的关键手段之一。然而&#xff0c;当多个模块在短时间内发布工单并且需要清理同一个接口的缓存时&#xff0c;容易引发缓存清理冲突&#xff0c;导致缓存失效的问题。为了解决这一难题&#xff0c;我们采用Redisson的消息队列…

【MCU学习】RTthread工程介绍

RT-Thread架构 RT-Thread诞生于2006年&#xff0c;是一款以开源、中立、社区化发展起来的物联网操作系统。 RT-Thread主要采用 C 语言编写&#xff0c;浅显易懂&#xff0c;且具有方便移植的特性&#xff08;可快速移植到多种主流 MCU 及模组芯片上&#xff09;。RT-Thread把面…

cocosCreator 之 ScrollView

版本&#xff1a;3.4.0 参考&#xff1a;ScrollView组件 简介 ScrollView组件作为滚动容器来使用&#xff0c;它的实现通过ScrollBar组件来展示内容的位置和Mask组件显示指定区域&#xff0c;来保证有限的区域内显示更多的内容。 它的构成部分&#xff1a; ScrollBar滚动条相…

03 shell 编程

变量 语言型 编译型语言 解释型语言 shell脚本语言是解释型语言shell脚本的本质&#xff1a;shell命令的有序集合 shell 编程的基本过程 基本过程分为三步&#xff1a; step1. 建立 shell 文件 包含任意多行操作系统命令或shell命令的文本文件; step2. 赋予shell文件执行…