策略模式+工厂模式(反射)+枚举代替 大量 if..else if..

实际项目中我们经常碰到需要使用if…else…if的分支判断这种情况。
这种写法带来一些弊端。
一旦分支多太多,逻辑复杂,会导致代码十分冗长,增加阅读难度。
如果需要增加或减少分支,需要改动if…elseif,增大因代码改动而出错的风险。

例如:
在这里插入图片描述

注:实际项目中的订单状态远远不止这些,小编只是模拟一个if…else…if 这样的一个场景

解决的方法是,可以通过策略模式+工厂模式,巧妙地利用反射机制和枚举类的valueof方法,规避掉if…else…if写法带来的弊端。下面我们通过一个订单状态这个实际例子来理解这种做法。

案例
状态策略接口

/*** 状态策略接口** @author gblfy* @date 2021-01-31*/
public interface StatusStrategy {void status();
}

未支付状态

/*** 未支付状态** @author gblfy* @date 2021-01-31*/
public class UnpaidStatus implements StatusStrategy {@Overridepublic void status() {System.out.println("未支付状态");}
}

未发货状态

/*** 未发货状态** @author gblfy* @date 2021-01-31*/
public class UnshippedStatus implements StatusStrategy {@Overridepublic void status() {System.out.println("未发货状态");}
}

已发货状态

/*** 已发货状态** @author gblfy* @date 2021-01-31*/
public class ShippedStatus implements StatusStrategy {@Overridepublic void status() {System.out.println("已发货状态");}
}

确认收货状态

/*** 确认收货状态** @author gblfy* @date 2021-01-31*/
public class ConfirmReceiptStatus implements StatusStrategy {@Overridepublic void status() {System.out.println("确认收货状态");}
}

已评价状态

/*** 已评价状态** @author gblfy* @date 2021-01-31*/
public class AlreadyEvaluatedStatus implements StatusStrategy {@Overridepublic void status() {System.out.println("已评价");}
}

状态枚举类

/*** 状态枚举类【如果需要增删状态类型,只需要在StatusEnum类添加或删除对应的枚举,而不是增删if…else if…】** @author gblfy* @date 2021-01-31*/
public enum StatusEnum {/*** 未支付状态*/UNPAIDSTATUS("com.gblfy.dca.task.UnpaidStatus"),/*** 未发货状态*/UNSHIPPEDSTATUS("com.gblfy.dca.task.UnshippedStatus"),/*** 已发货状态*/SHIPPEDSTATUS("com.gblfy.dca.task.ShippedStatus"),/*** 确认收货状态*/CONFIRMRECEIPTSTATUS("com.gblfy.dca.task.ConfirmReceiptStatus"),/*** 已评价状态*/ALREADYEVALUATEDSTATUS("com.gblfy.dca.task.AlreadyEvaluatedStatus");StatusEnum(String className) {this.setClassName(className);}private String className;public String getClassName() {return className;}public void setClassName(String className) {this.className = className;}
}

状态工厂类

/*** 状态工厂类** @author gblfy* @date 2021-01-31*/
public class StatusFactory {/*** 该工厂类提供静态方法,巧妙地利用反射机制和枚举类的valueof方法,返回具体策略实例。* @param strategyType 策略类型* @return* @throws Exception*/public static StatusStrategy getStrategy(String strategyType) throws Exception {String className = StatusEnum.valueOf(strategyType).getClassName();return (StatusStrategy) Class.forName(className).newInstance();}
}

测试类

public class Demo {public static void main(String[] args) throws Exception {String statusStrategyParam = "UNPAIDSTATUS";//未支付状态StatusStrategy strategy = StatusFactory.getStrategy(statusStrategyParam);strategy.status();statusStrategyParam = "UNSHIPPEDSTATUS";//未发货状态strategy = StatusFactory.getStrategy(statusStrategyParam);strategy.status();statusStrategyParam = "SHIPPEDSTATUS";//已发货状态strategy = StatusFactory.getStrategy(statusStrategyParam);strategy.status();statusStrategyParam = "CONFIRMRECEIPTSTATUS";//确认收货状态strategy = StatusFactory.getStrategy(statusStrategyParam);strategy.status();statusStrategyParam = "ALREADYEVALUATEDSTATUS";//已评价状态strategy = StatusFactory.getStrategy(statusStrategyParam);strategy.status();}
}

控制调输出

未支付状态
未发货状态
已发货状态
确认收货状态
已评价

总结

            if…else if…的缺点

1.多分支和复杂度高的逻辑会使代码冗长,难以理解和维护。

2.增删分支需要改动if…else if结构,增大代码出错风险。

            策略模式+工厂模式的优点

1.对应的分支处理分成不同策略类来实现,使代码易于读懂和维护

2.扩展性好,增加分支只需要增加对应的策略实现类和枚举。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开发函数计算的正确姿势 —— Fun validate 语法校验排错指南

1. 前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源…

我最喜欢的云 IDE 推荐!

云IDE——这是我最喜欢的一种完全避免管理开发环境的新方法。作者 | David Kramer译者 | 弯月,责编 | 郭芮头图 | CSDN 下载自东方 IC出品 | CSDN(ID:CSDNnews)以下为译文:设置和维护开发环境是一件非常麻烦的事情。如…

优化if-else代码的八种方案!

文章目录1. 优化方案一:提前return,去除不必要的else2. 优化方案二:使用条件三目运算符3. 优化方案三:使用枚举4. 优化方案四:合并条件表达式5. 优化方案五:使用 Optional6. 优化方案六:表驱动法…

阿里五年晋升三次,这个程序员要聊聊他的选择

小二穆远是蚂蚁金服的一名程序员,五年晋升了三次,他要聊聊自己的五年阿里之旅,那些变化、坚持和泪水。请看本期的年陈故事会。 说起与阿里的缘分,是因为读书时在T公司实习,不喜欢实习那个组的工作内容,毅然…

IP应用加速技术详解:如何提升动静混合站点的访问速率?

全站加速(DCDN)-IPA是阿里云自主研发四层加速产品,它基于TCP/UDP的私有协议提供加速服务,包括解决跨运营商网络不稳定、单线源站、突发流量、网络拥塞等诸多因素导致的延迟高、服务不稳定的问题,提升传输性能和用户体验…

Java-记一次if-else代码优化

https://artisan.blog.csdn.net/article/details/86703136

2020 年最新版 68 道Redis面试题,20000 字干货,赶紧收藏起来备用!

作者 | ThinkWon责编 | 徐威龙来源 | CSDN 博客封图| CSDN 下载于视觉中国Redis(Remote Dictionary Server) 是一个使用 C 语言编写的,开源的(BSD许可)高性能非关系型(NoSQL)的键值对数据库。Redis 可以存储键和五种不…

异常检测的N种方法,阿里工程师都盘出来了

阿里妹导读:互联网黑产盛行,其作弊手段层出不穷,导致广告效果降低,APP推广成本暴增。精准识别作弊是互联网公司和广告主的殷切期望。今天我们将从时间序列、统计、距离、线性方法、分布、树、图、行为序列、有监督机器学习和深度学…

TalkingData的Spark On Kubernetes实践

众所周知,Spark是一个快速、通用的大规模数据处理平台,和Hadoop的MapReduce计算框架类似。但是相对于MapReduce,Spark凭借其可伸缩、基于内存计算等特点,以及可以直接读写Hadoop上任何格式数据的优势,使批处理更加高效…

ORACLE使用批量插入100万测试数据

CREATE TABLE test_data (ID varchar2(32),NAME1 varchar2(9),NAME2 varchar2(100),NAME3 varchar2(100) ); COMMENT ON TABLE test_data IS 测试表;beginfor i in 1 .. 1000000 loopINSERT INTO "DCA"."TEST_DATA" ("ID", "NAME1", &…

阿里技术男的成长史:越想证明自己死得越快……

在上海工作8年后,身为部门经理的钱磊,管理着一家ERP公司的百十来号员工,“再往上爬就是老板和他儿子了……从这个领域的技术角度来讲算是做到了顶。”05年,钱磊就开始关注一家名字奇怪,做事也奇怪的公司。 要不要折腾…

程序员1w5以下的,2020年就要面对现实了...

BOSS直聘最近发布,“互联网行业30%新增岗位,全都是技术岗!各公司开启了新一轮抢人计划”。大家在这个春招一定有很多目标,找到理想工作,换个大房子住,给爸妈多寄点钱,给女朋友换个新手机……CSD…

MYSQL用存储过程创建百万级测试数据表

1.创建随机字符串函数,便于创建名称 -- delimiter $$ -- 执行出现“This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled -- (you *might* want to use the less safe log_bin_trust_function_…

对话亲历者|鲁肃:我在支付宝“拧螺丝“的日子

对话亲历者:他是支付宝技术平台的奠基人之一,但是他总说“这还不是我心中最完美的架构”;他行事低调但却有着“此时此地,非我莫属”的豪气;他曾无数次充当救火大队长,但自评只是“没有掉队的那个人”。 在2…

Flutter高内聚组件怎么做?阿里闲鱼打造开源高效方案!

fish_redux是闲鱼技术团队打造的flutter应用开发框架,旨在解决页面内组件间的高内聚、低耦合问题。开源地址:https://github.com/alibaba/fish-redux 从react_redux说起 redux对于前端的同学来说是一个比较熟悉的框架了,fish_redux借鉴了re…

AI赋能红外测温助力精准防控疫情……

文章来源:北京领邦智能装备股份公司 疫情发生以来,全国上下倾力奋战得到有效控制,科技抗疫逐渐成为有效抓手,而AI红外热成像测温仪无疑将成为抗疫一线的一把利剑,斩断疫情传播的途径。 需求引领技术变革 2003年非典后…

mysql 通过存储过程 插入测试百万数据

#mysql -uroot -p123456create database gblfy; use gblfy create table test(name varchar(10),age int,height int);//创建过程 use gblfy drop procedure if exists test1; DELIMITER $$ CREATE PROCEDURE test1() begin DECLARE i int DEFAULT 1; WHILE i<1000000 DO in…

阿里巴巴中间件在 Serverless 技术领域的探索

Serverless 话题涉及范围极广&#xff0c;几乎包含了代码管理、测试、发布、运维和扩容等与应用生命周期关联的所有环节。AWS Lambda 是 Serverless 领域的标志性产品&#xff0c;但如果将其应用于核心业务&#xff0c;可能会遇到以下难题&#xff1a;&#xff08;仅代表作者个…

从零单排HBase 02:全面认识HBase架构(建议收藏)

作者 | 阿丸笔记责编 | 徐威龙封图| CSDN 下载于视觉中国在网上看过很多HBaes架构相关的文章&#xff0c;内容深浅不一&#xff0c;直到发现了一篇MapR官网的文章&#xff0c;写得实在太生动了。https://mapr.com/blog/in-depth-look-hbase-architecture/#.VdMxvWSqqko&#xf…

ORACLE JDBC 对千万数据 批量删除和批量插入

文章目录1. 表结构2. 批量删除3. 批量插入4. 批量删除和插入5. 实体类6. main1. 表结构 -- Create table create table HERO (SNO VARCHAR2(20) not null,USER_NAME VARCHAR2(20),AGE NUMBER(30) );comment on table HERO is 英雄信息表;comment on column HERO.S…