策略模式+SpringBoot自动注入

本文展示了如何在SpringBoot环境下解决策略模式下bean注入为null的问题。通过创建一个工厂类,利用@PostConstruct注解初始化策略,并根据枚举类型调用相应策略的方法,实现了动态策略选择。测试调用证明了方案的有效性。
摘要由CSDN通过智能技术生成

策略模式+SpringBoot自动注入

解决springboot环境中策略模式不能注入bean问题,例如导致注入DAO为null
话不多说,上代码
1公共接口


public interface BusinessStrategy{

    public void doOperation(String json);

	//根据枚举类型分配策略
    ScheduleTypeEnum getStyle();
}

2策略1

@Service
public class BusinessStrategyOneImpl implements BusinessStrategy{


    @Resource
    BusinessDAO BusinessDAO ;

    @Override
    public void doOperation(String json) {
       
    }

    @Override
    public ScheduleTypeEnum getStyle() {
        return ScheduleTypeEnum.ONE;
    }

策略2

@Service
public class BusinessStrategyTwoImpl implements BusinessStrategy{


    @Resource
    BusinessDAO BusinessDAO ;

    @Override
    public void doOperation(String json) {
       
    }

    @Override
    public ScheduleTypeEnum getStyle() {
        return ScheduleTypeEnum.TWO;
    }

策略3

@Service
public class BusinessStrategyThreeImpl implements BusinessStrategy{


    @Resource
    BusinessDAO BusinessDAO ;

    @Override
    public void doOperation(String json) {
       
    }

    @Override
    public ScheduleTypeEnum getStyle() {
        return ScheduleTypeEnum.THREE;
    }

3定义Factory

@Service
public class StrategyFactory {

    private final List<BusinessStrategy> strategy;
    
    public StrategyFactory (List<BusinessStrategy> strategy) {
        this.strategy = strategy;
    }

    private Map<String,BusinessStrategy> strategies = new ConcurrentHashMap<>();

    /**
     * 提前注入
     */
    @PostConstruct
    public void initStrategy() {
        Optional.ofNullable(strategy).orElseGet(ArrayList::new)
                .forEach(tracer -> {
                    strategies.put(tracer.getStyle().getType(), tracer);
                });

    }

    /**
     * 上下文对象暴露给服务调用端接口,封装实现方式
     * @param needIdea
     */
    public void useStrategiesg(String type,String json){
        strategies.get(type).doOperation(json);
    }
    
}

4测试调用

 	@Resource
    private StrategyFactory factory;
   	@Test
    public void testStart() throws InterruptedException {
      factory.useStrategiesg("one","businessData");
    }
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,下面我给你讲一下如何在Spring Boot中实现策略模式。 首先,我们需要定义一个接口或者抽象,用于定义策略模式中的抽象行为。以一个简单的计算器为例,我们可以定义一个`Calculator`接口,其中包含一个`calculate`方法: ```java public interface Calculator { int calculate(int a, int b); } ``` 然后,我们需要定义具体的策略实现`Calculator`接口。假设我们有两种计算方式:加法和乘法,我们可以分别定义两个实现: ```java @Component public class AddCalculator implements Calculator { @Override public int calculate(int a, int b) { return a + b; } } @Component public class MultiplyCalculator implements Calculator { @Override public int calculate(int a, int b) { return a * b; } } ``` 在上面的代码中,我们使用了`@Component`注解将这两个注册为Spring Bean,以便在其他地方可以自动注入它们。 接下来,我们需要一个Context,用于选择具体的策略。在Spring Boot中,我们可以使用`@Autowired`注解自动注入所有实现了`Calculator`接口的Bean,并使用`@Qualifier`注解来指定具体的实现。例如: ```java @Service public class CalculatorService { @Autowired private List<Calculator> calculators; public int calculate(String operator, int a, int b) { for (Calculator calculator : calculators) { if (calculator.getClass().getSimpleName().equalsIgnoreCase(operator)) { return calculator.calculate(a, b); } } throw new IllegalArgumentException("Invalid operator: " + operator); } } ``` 在上面的代码中,我们使用了一个`List<Calculator>`来注入所有实现了`Calculator`接口的Bean。然后,我们在`calculate`方法中根据传入的运算符选择具体的策略,并调用它的`calculate`方法进行计算。 最后,我们可以在Controller中使用`CalculatorService`实现具体的业务逻辑。例如: ```java @RestController public class CalculatorController { @Autowired private CalculatorService calculatorService; @GetMapping("/calculate") public int calculate(@RequestParam String operator, @RequestParam int a, @RequestParam int b) { return calculatorService.calculate(operator, a, b); } } ``` 在上面的代码中,我们使用了`@RequestParam`注解来接收请求参数,然后调用`CalculatorService`的`calculate`方法进行计算,并返回结果。 这就是在Spring Boot中实现策略模式的方法。希望对你有帮助!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值