增强版的策略模式

2024-04-23 13:58
文章标签 模式 策略 增强版

本文主要是介绍增强版的策略模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

策略模式

就是一个类的方法可以在运行时修改。降维到代码层面,就是运行的时候我给你这个类的方法传不同的 “key”,你这个方法就会执行不同的业务逻辑,这不就是if/else做的事。也就是运行时改变业务逻辑行为。

//抽象策略接口
public interface AbstractStrategy {void executeDiscount();
}//策略实现类
public class CommonManStrategy implements AbstractStrategy {@Overridepublic void executeDiscount() {System.out.println("执行普通用户的优惠!!");}
}
public class MemberStrategy implements AbstractStrategy {@Overridepublic void executeDiscount() {System.out.println("执行会员的优惠!!!");}
}//逻辑分派类/*** 逻辑分发器*/
public class StrategyDistriutor {//组合策略private AbstractStrategy abstractStrategy;public StrategyDistriutor(AbstractStrategy abstractStrategy) {this.abstractStrategy = abstractStrategy;}//执行策略public void executeDiscount(){abstractStrategy.executeDiscount();}
/*** 策略设计模式,运行时改变业务逻辑行为。*/
public class StrategyPattern {public static void main(String[] args) {StrategyDistriutor strategyDistriutor = new StrategyDistriutor(new CommonManStrategy());strategyDistriutor.executeDiscount();StrategyDistriutor memberStrategy =  new StrategyDistriutor(new MemberStrategy());memberStrategy.executeDiscount();}
}

策略模式的优点是将策略抽象出来,使结构更加的清晰,好维护。缺点是当策略多时,需要创建数量庞大的策略类。并且,不能全局的俯视业务逻辑。

当然,有缺点自然就会有人优化。这不阿里的大神就分享出来一条解决的思路。话不多说,直接上代码。

先上思路导图:
在这里插入图片描述

/*** 业务集合类*/
@Component
public class BusinessGather {public Object rookieGiftRelease(){System.out.println("新手礼包发布");return "发布成功!";}public Object holidayInfoRelease(){System.out.println("节日信息发布");return "发布成功!";}}/*** Map组合函数式接口解决策略模式类多,遍历全局业务逻辑困难的场景。*/
@Component
public class FunctionMapMode {@Autowiredprivate BusinessGather businessGather;public FunctionMapMode(BusinessGather businessGather) {initStrategyMap();this.businessGather = businessGather;}private static Map<Object, Function<Object,Object>> businessMap = new HashMap<>();public void initStrategyMap(){businessMap.put("rookieGiftRelease",s -> businessGather.rookieGiftRelease());businessMap.put("holidayInfoRelease",s -> businessGather.holidayInfoRelease());}public void release(Object o){Function<Object,Object> function = businessMap.get(o);function.apply(o);}
}public class NewModePattern {public static void main(String[] args) {//这里直接new,因为没启动spring容器FunctionMapMode functionMapMode = new FunctionMapMode(new BusinessGather());functionMapMode.release("rookieGiftRelease");functionMapMode.release("holidayInfoRelease");}
}

是不是超级简单且非常有用,在日常的开发业务中也能很好的运用上去。

还在等什么呢,老铁,点赞加收藏呀!!

装逼技术哪家强,博客之中我最强,嘻嘻,喜欢就关注我吧。
在这里插入图片描述

这篇关于增强版的策略模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/928986

相关文章

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR