您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Java中怎么用策略模式實現條件判斷”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Java中怎么用策略模式實現條件判斷”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
策略模式定義了一系列算法,并且將每個算法封裝起來,使得他們可以相互替換,而且算法的變化不會影響使用算法的客戶端。
一個系統需要動態的在幾種算法中選擇一種,可以把每個算法封裝到具體的策略類中
一個類中定義了多種行為,可以去代替條件轉移語句,減少硬編碼
系統中各個算法或者說函數是彼此獨立的,而且要求對客戶隱藏算法具體實現細節的時候
多個類只區別在表現行為的不同,可以使用策略模式,在運行時動態的選擇要執行的行為
根據不同的水果口味,制作不同的蛋糕,比如現在有蘋果味和香蕉味的蛋糕,入參為蘋果味,則制作蘋果味蛋糕;入參為香蕉味,則制作香蕉味的蛋糕
定義制作蛋糕的抽象類
/** * 蛋糕制作抽象類 * @author:liyajie * @createTime:2022/2/24 10:53 * @version:1.0 */ public abstract class CakeHandler { /** * 制作蛋糕 * @author: liyajie * @date: 2022/2/24 10:54 * @param * @return void * @exception: * @update: * @updatePerson: **/ public abstract void makeCake(); }
定義制作蘋果味蛋糕的策略類,繼承制作蛋糕抽象類,重寫makeCake方法
/** * 制作蘋果蛋糕策略 * @author:liyajie * @createTime:2022/2/24 10:55 * @version:1.0 */ public class AppleCakeHandler extends CakeHandler{ @Override public void makeCake() { System.out.println("正在制作蘋果蛋糕"); } }
定義制作香蕉味蛋糕的策略類,繼承制作蛋糕抽象類,重寫makeCake方法
/** * 制作香蕉蛋糕策略 * @author:liyajie * @createTime:2022/2/24 10:55 * @version:1.0 */ public class BananaCakeHandler extends CakeHandler{ @Override public void makeCake() { System.out.println("正在制作香蕉蛋糕"); } }
定義枚舉類,來制作蛋糕的策略
/** * 制作蛋糕枚舉 * @author:liyajie * @createTime:2022/2/24 10:57 * @version:1.0 */ public enum CakeEnum { APPLE(AppleCakeHandler.class.getSimpleName(),new AppleCakeHandler()), BANANA(BananaCakeHandler.class.getSimpleName(),new BananaCakeHandler()); private final String cakeType; private final CakeHandler cakeHandler; CakeEnum(String cakeType, CakeHandler cakeHandler){ this.cakeType = cakeType; this.cakeHandler = cakeHandler; } // 匹配策略類 public static CakeEnum match(String cakeType){ CakeEnum[] values = CakeEnum.values(); for (CakeEnum cakeEnum : values) { if(cakeType.equals(cakeEnum.cakeType)){ return cakeEnum; } } return null; } public String getCakeType(){ return cakeType; } public CakeHandler getCakeHandler(){ return cakeHandler; } }
定義測試類
/** * 測試類 * @author:liyajie * @createTime:2022/2/24 11:07 * @version:1.0 */ public class Test { public static void main(String[] args) { String cakeType = AppleCakeHandler.class.getSimpleName(); CakeEnum cakeEnum = CakeEnum.match(cakeType); CakeHandler cakeHandler = cakeEnum.getCakeHandler(); cakeHandler.makeCake(); cakeType = BananaCakeHandler.class.getSimpleName(); cakeEnum = CakeEnum.match(cakeType); cakeHandler = cakeEnum.getCakeHandler(); cakeHandler.makeCake(); } }
查看測試結果
通過該案例的實現,我們可以看到,使用策略模式+枚舉,替換掉了if--else的硬編碼,并且把不同的策略封裝到了單獨的實現類中,防止一個策略出現問題后影響到其他的策略,提高了系統的可擴展性,最大程度上實現了開閉原則。
優勢
多重條件語句屬于硬編碼不易維護,而使用策略模式可以避免使用多重條件語句
策略模式提供了一系列算法,恰當的使用繼承或者實現,可以把算法族里面的公共代碼提到父類里面。這樣就會避免重復的代碼
策略模式可以提供相同行為的不同實現,客戶端可以根據具體的業務邏輯去選擇合適的
策略模式完美契合開閉原則,可以在不修改或者少修改源代碼的情況下,靈活增加、減少、修改新 算法
策略模式把算法的使用放到環境類中,而算法的實現在具體策略類中,實現了二者的分離
劣勢
在實際業務邏輯非常復雜的情況下,會導致出現很多策略類
客戶端必須在恰當的時候,使用恰當的算法類,才能合理完成業務邏輯
讀到這里,這篇“Java中怎么用策略模式實現條件判斷”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。