Spring中策略模式实现方法

一、定义

在策略模式(Strategy Pattern)中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为型模式。在策略模式中,我们创建表示各种策略的对象和一个行为随着策略对象改变而改变的 context 对象。策略对象改变 context 对象的执行算法。由于spring中我们需要注册对象,不能通过直接通过 **new** 来创建策略实现类,需要使用工厂模式来获取bean对象

二、实现方法

1.策略模式接口

public interface StrangeService {

     int executeStrange(int id, double credit);

}

2.定义策略模式的实现类

StrangeActivityAddServiceImpl和、StrangeActivitySubServiceImpl

StrangeActivityAddServiceImpl

@Service
@Slf4j
public class StrangeActivityAddServiceImpl implements StrangeService{

    @Autowired
    private ActivityMapper activityMapper;

    @Override
    public int executeStrange(int id, double credit) {
        log.info("传入参数:id=[{}],credit=[{}]",id,credit);
        Activity activity=activityMapper.selectByPrimaryKey(id);
        activity.setCredit(activity.getCredit()+credit);
        int res=activityMapper.updateByPrimaryKeySelective(activity);
        System.out.println("增加积分策略结果:"+res);
        return res;
    }
}

StrangeActivitySubServiceImpl

@Service
@Slf4j
public class StrangeActivitySubServiceImpl implements StrangeService{
    @Autowired
    private ActivityMapper activityMapper;

    @Override
    public int executeStrange(int id, double credit) {
        log.info("传入参数:id=[{}],credit=[{}]",id,credit);
        Activity activity=activityMapper.selectByPrimaryKey(id);
        activity.setCredit(activity.getCredit()-credit);
        int res=activityMapper.updateByPrimaryKeySelective(activity);
        System.out.println("增加积分策略结果:"+res);
        return res;
    }
}

3.策略模式上下文

用于获取注入的策略实现类的bean对象

(1)通过ConcurrentHashMap的形式获取注入的对象

@Service
public class StrangeContext {

    @Autowired
    private final Map<String, StrangeService> map = new ConcurrentHashMap<>();

    /**
     * 根据服务实现类名称获取对应的服务
     * @param serviceName
     * @return
     */
    public StrangeService strangeService(String serviceName) {
        StrangeService strangeService = map.get(serviceName);
        if (strangeService == null) {
            throw new RuntimeException("未定义此策略实现类!");
        }
        return strangeService;
    }

}

(2)通过SpringContextHolder重写ApplicationContextAware获取上下文对象获取指定bean

StrangeService strangeService=SpringContextHolder.getBean(StrangeActivityConstant.STRANGE_CREDIT_ADD_SERVICE,StrangeActivityAddServiceImpl.class);
strangeService.executeStrange(1,1);

4.策略模式实现类常量名

public interface StrangeActivityConstant {

    String STRANGE_CREDIT_ADD_SERVICE = "strangeActivityAddServiceImpl";

    String STRANGE_CREDIT_MULTIPLY_SERVICE = "strangeActivityMultiServiceImpl";

    String STRANGE_CREDIT_SUBTRACT_SERVICE = "strangeActivitySubServiceImpl";
}

5.使用方式

在spring中注入上下文StrangeContext对象,然后执行方法获取currentHashMap中策略实现类Impl的bean对象,再调用策略实现类Impl的具体实现方法

@Autowired
private StrangeContext strangeContext;

@RequestMapping("/test15")
public void testStrangePattern(){
    //为活动id=1的活动增加积分
strangeContext.strangeService(StrangeActivityConstant.STRANGE_CREDIT_ADD_SERVICE).executeStrange(1,9);

    //为活动id=3的活动减去积分
strangeContext.strangeService(StrangeActivityConstant.STRANGE_CREDIT_SUBTRACT_SERVICE).executeStrange(3,1);
}

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用Spring框架实现策略模式的示例: 首先,定义一个策略接 `Strategy`,包含一个 `execute()` 方法: ```java public interface Strategy { void execute(); } ``` 然后,创建几个具体的策略类实现该接口: ```java @Component public class StrategyA implements Strategy { @Override public void execute() { System.out.println("执行策略A"); } } @Component public class StrategyB implements Strategy { @Override public void execute() { System.out.println("执行策略B"); } } @Component public class StrategyC implements Strategy { @Override public void execute() { System.out.println("执行策略C"); } } ``` 接下来,创建一个策略上下文类 `StrategyContext`,并使用Spring的依赖注入功能将所有的策略类注入进来: ```java @Component public class StrategyContext { private final Map<String, Strategy> strategyMap; public StrategyContext(List<Strategy> strategies) { this.strategyMap = strategies.stream().collect(Collectors.toMap(Strategy::getClass.getSimpleName, Function.identity())); } public void executeStrategy(String strategyName) { Strategy strategy = strategyMap.get(strategyName); if (strategy != null) { strategy.execute(); } else { throw new IllegalArgumentException("Unsupported strategy: " + strategyName); } } } ``` 最后,在其他需要使用策略模式的地方,可以通过依赖注入 `StrategyContext` 对象,并调用其 `executeStrategy()` 方法执行相应的策略: ```java @Component public class SomeService { private final StrategyContext strategyContext; public SomeService(StrategyContext strategyContext) { this.strategyContext = strategyContext; } public void doSomething(String strategyName) { strategyContext.executeStrategy(strategyName); } } ``` 这样,通过使用Spring框架的依赖注入功能,我们可以方便地在运行时动态切换不同的策略实现

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值