詳解SpringBoot結(jié)合策略模式實戰(zhàn)套路
1.1. 前言
我們都知道設計模式好,可以讓我們的代碼更具可讀性,擴展性,易于維護,但大部分程序猿一開始都學過至少一遍設計模式吧,實戰(zhàn)中不知用到了幾成。接下來讓我介紹一個結(jié)合SpringBoot的策略模式套路,讓你的代碼少些if-else
1.2. 開擼
廢話不多說,直接告訴你今天的核心是@autowired,看到這個是不是很熟悉,你每天都在用,不就是自動注入Spring管理的Bean嗎?但我們對它的用法很多時候就局限在全局變量的注入了,忘記了,它其實還可以構(gòu)造器注入,類型注入或命名注入,那么結(jié)合策略模式會綻放怎樣的火花呢?跟著我的代碼來看
1.2.1. 計算策略接口
/**
* @author laoliangliang
* @date 2019/10/28 10:10
*/
public interface CalculateStrategy {
int doOperation(int num1,int num2);
}
1.2.2. 實現(xiàn)類
分別實現(xiàn)加減乘三個運算,可以看到我用了spring的注解@Component,也就是實例由spring管理了
@Component
public class AddOperation implements CalculateStrategy {
@Override
public int doOperation(int num1, int num2) {
return num1 + num2;
}
}
@Component
public class SubstractOperation implements CalculateStrategy {
@Override
public int doOperation(int num1, int num2) {
return num1 - num2;
}
}
@Component
public class MultiplyOperation implements CalculateStrategy {
@Override
public int doOperation(int num1, int num2) {
return num1 * num2;
}
}
1.2.3. 上下文
之后創(chuàng)建上下文管理,用于提取策略。這個上下文才是本文的重點,注意到@autowired注解放的位置和對應的參數(shù)列表了嗎?實際上它還可以注入到Map和List,Map的key就是它注入時的名,List則是存放全部實例對象
import com.google.common.base.Preconditions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
/**
* @author laoliangliang
* @date 2019/10/28 10:14
*/
@Component
public class CalculatelOperationContext {
// @Autowired
// private Map<String, CalculateStrategy> strategyMap;
private final Map<String, CalculateStrategy> strategyMap = new ConcurrentHashMap<>();
@Autowired
public void stragegyInteface(Map<String, CalculateStrategy> strategyMap) {
this.strategyMap.clear();
strategyMap.forEach(this.strategyMap::put);
System.out.println(this.strategyMap);
}
@Autowired
public void stragegyInteface2(List<CalculateStrategy> strategyMap) {
strategyMap.forEach(System.out::println);
}
public CalculateStrategy strategySelect(String mode) {
Preconditions.checkArgument(!StringUtils.isEmpty(mode), "不允許輸入空字符串");
return this.strategyMap.get(mode);
}
}
打印結(jié)果:
{multiplyOperation=com.laoliang.springboot.pattern.strategy.MultiplyOperation@372ea2bc, addOperation=com.laoliang.springboot.pattern.strategy.AddOperation@4cc76301, substractOperation=com.laoliang.springboot.pattern.strategy.SubstractOperation@2f08c4b}
com.laoliang.springboot.pattern.strategy.AddOperation@4cc76301
com.laoliang.springboot.pattern.strategy.MultiplyOperation@372ea2bc
com.laoliang.springboot.pattern.strategy.SubstractOperation@2f08c4b
可以看到Map中key,value的關(guān)系,key的默認值為類的第一個字母小寫
1.2.4. 控制層
/**
* @author laoliangliang
* @date 2019/10/28 10:52
*/
@RestController
public class StrategyController {
@Autowired
private CalculatelOperationContext calculatelOperationContext;
@RequestMapping(value = "/operation")
public String strategySelect(@RequestParam("mode") String mode) {
return String.valueOf(calculatelOperationContext.strategySelect(mode).doOperation(20, 5));
}
}
啟動SpringBoot,瀏覽器調(diào)用http://localhost:8080/operation?mode=multiplyOperation,結(jié)果100。模式可以選擇另外兩個addOperation和substractOperation
我這里就做個演示,輸入?yún)?shù)就寫固定了,可以看到我們通過上下文calculatelOperationContext調(diào)用其方法strategySelect,通過不同的調(diào)用參數(shù)獲得不同的策略,所以業(yè)務中只要可以抽象的方法都可以改寫成這樣的模式。
這種模式套路的好處就是當你要新增一種策略,比如除法,你不需要修改原來的代碼,只要抽象不變,你新增一個DivideOperation類實現(xiàn)CalculateStrategy策略接口加上Spring注解即可,調(diào)用時模式修改為divideOperation就可以實現(xiàn)調(diào)用了,耦合性大大降低,不需要再改原來那一坨自己都看不下去的代碼了
1.3. 總結(jié)
可以看到全文中代碼量還是相對比較少的,將不同的策略用不同的類實現(xiàn),且可以不用改動別的代碼,這篇文章你get到新套路了嗎
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring實現(xiàn)Aware接口自定義獲取bean的兩種方式
這篇文章主要介紹了Java編程實現(xiàn)Aware接口自定義獲取bean的兩種方式,通過BeanFactoryAware和ApplicationContextAware,具有一定參考價值,需要的朋友可以了解下。2017-09-09
Spring?boot?運用策略模式實現(xiàn)避免多次使用if
這篇文章主要介紹了Spring?boot?運用策略模式實現(xiàn)避免多次使用if,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09

