Java设计模式---策略模式

策略模式(Strategy Pattern)是一种行为设计模式,它定义了一系列算法(或策略),并将每个算法封装起来,使得它们可以互相替换。策略模式允许算法的变化独立于使用算法的客户(即客户端代码)。简而言之,它让我们可以在运行时选择具体的算法,避免了大量的 if-elseswitch 语句。

策略模式的组成部分

策略模式主要有以下几个组成部分:

  1. Context(上下文):持有一个策略的引用,可以更换不同的策略来执行某个操作。
  2. Strategy(策略接口):定义一个策略接口,通常这个接口包含一个方法,这个方法是被策略实现类所共享的。
  3. ConcreteStrategy(具体策略):具体的策略类,实现策略接口,定义具体的算法或行为。
  4. Client(客户端):通过设置策略(ConcreteStrategy)来决定使用哪种具体策略。

策略模式的结构图

+---------------------+

| Context |

+---------------------+

| - strategy: Strategy |

+---------------------+

| + setStrategy() |

| + execute() |

+---------------------+

^

|

+-----------+-----------+

| |

+--------------+ +--------------+

| Strategy | | ConcreteStrategyA |

+--------------+ +---------------------+

| + algorithm()| | + algorithm() |

+--------------+ +---------------------+

+---------------------+

| ConcreteStrategyB |

+---------------------+

| + algorithm() |

+---------------------+

1.方法入口

java 复制代码
@Component
public class AppContext {
    @Autowired
    private List<AppStrategy> userAppStrategyList;

    private final Map<String, AppStrategy> STRATEGYMAP = new HashMap<>();

    @PostConstruct
    public void init() {
        userAppStrategyInterfaceList.forEach(strategy -> {
            STRATEGYMAP.put(strategy.type(), strategy);
        });
    }


    public void add(UserDto userDto) {
        STRATEGYMAP.entrySet().stream()
                .filter(entry -> entry.getKey().contains(userDto.getType().toString()))
                .findFirst()
                .ifPresent(entry -> entry.getValue().add(userDto));
    }

    
}

2.接口

java 复制代码
public interface AppStrategy {
    String type();

    void add(UserDto dto);

    
}

3.实现类

实现类1

java 复制代码
@Service
@Slf4j
public class AppCompanyService implements AppStrategy {
    
    @Override
    public String type() {
        return "1,2";
    }

    @Override
    public void add(UserDto dto) {
        log.info("调用了实现类1");
    }
}

实现类2

java 复制代码
@Service
@Slf4j
public class AppPersonService implements AppStrategy {
    
    @Override
    public String type() {
        return "3,4";
    }

    @Override
    public void add(UserDto dto) {
        log.info("调用了实现类2");
    }
}

4.调用

java 复制代码
@Service
@Slf4j
public class AppUserService {
    @Resource
    private AppContext appContext;

    @GlobalTransactional
    public void add(UserDto userDto) throws Exception {
        userDto.setType(1);
        appIdentityContext.add(userIdentityDto);
    }
}

这样就完成了一个策略模式的小demo。

相关推荐
better_liang2 小时前
每日Java面试场景题知识点之-消息队列MQ核心场景与实战
java·面试·kafka·消息队列·rabbitmq·rocketmq·mq
小江的记录本3 小时前
【JVM虚拟机】垃圾回收GC:四种引用类型:强引用、软引用、弱引用、虚引用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
小马爱打代码3 小时前
Spring源码 第四篇:Spring 5 源码深度拆解:AOP 全流程核心原理
java·后端·spring
better_liang3 小时前
每日Java面试场景题知识点之-SpringBoot启动流程
java·面试·springboot·源码解析·启动流程
RyFit3 小时前
Java + AI 实战:Spring AI 从入门到企业级落地
java·人工智能·spring
ZhengEnCi5 小时前
01-如何监听接口调用情况?
java·spring boot·后端
JAVA面经实录9176 小时前
MyBatis学习体系
java·mybatis
java1234_小锋6 小时前
在 Spring AI 中如何实现函数调用(Function Calling)?请说明其基本原理和应用场景。
java·人工智能·spring
小马爱打代码6 小时前
Spring源码 第九篇:Spring 5 源码深度拆解 - Spring 事件驱动模型
java·后端·spring
ForgeAI码匠7 小时前
ForgeAdmin|Spring Boot 3 后台框架的自动配置设计:少写配置,多做组合
java·spring boot·后端