咱們都知道設計模式好,可讓咱們的代碼更具可讀性,擴展性,易於維護,但大部分程序猿一開始都學過至少一遍設計模式吧,實戰中不知用到了幾成。接下來讓我介紹一個結合SpringBoot的策略模式套路,讓你的代碼少些if-elsejava
廢話很少說,直接告訴你今天的核心是@autowired
,看到這個是否是很熟悉,你天天都在用,不就是自動注入Spring管理的Bean嗎?但咱們對它的用法不少時候就侷限在全局變量的注入了,忘記了,它其實還能夠構造器注入,類型注入或命名注入,那麼結合策略模式會綻開怎樣的火花呢?跟着個人代碼來看spring
/** * @author laoliangliang * @date 2019/10/28 10:10 */ public interface CalculateStrategy { int doOperation(int num1,int num2); }
分別實現加減乘三個運算,能夠看到我用了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; } }
以後建立上下文管理,用於提取策略。這個上下文才是本文的重點,注意到@autowired
註解放的位置和對應的參數列表了嗎?實際上它還能夠注入到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); } }
打印結果:springboot
{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的關係,key的默認值爲類的第一個字母小寫app
/** * @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,瀏覽器調用http://localhost:8080/operation?mode=multiplyOperation
,結果100。模式能夠選擇另外兩個addOperation
和substractOperation
ide
我這裏就作個演示,輸入參數就寫固定了,能夠看到咱們經過上下文calculatelOperationContext
調用其方法strategySelect
,經過不一樣的調用參數得到不一樣的策略,因此業務中只要能夠抽象的方法均可以改寫成這樣的模式。學習
這種模式套路的好處就是當你要新增一種策略,好比除法,你不須要修改原來的代碼,只要抽象不變,你新增一個DivideOperation
類實現CalculateStrategy
策略接口加上Spring註解便可,調用時模式修改成divideOperation
就能夠實現調用了,耦合性大大下降,不須要再改原來那一坨本身都看不下去的代碼了this
能夠看到全文中代碼量仍是相對比較少的,將不一樣的策略用不一樣的類實現,且能夠不用改動別的代碼,這篇文章你get到新套路了嗎google
接下來我爭取每篇文章下都分享一套學習視頻,但願大家喜歡!!龍果學院 秒殺系統企業級實戰應用(真實工業界案例)視頻