C#/.NET 策略模式初入門檻
阿新 • • 發佈:2019-01-09
C# 策略模式
在策略模式(Strategy Pattern)中,一個類的行為或其演算法可以在執行時更改。這種型別的設計模式屬於行為型模式。
在策略模式中,我們建立表示各種策略的物件和一個行為隨著策略物件改變而改變的 context 物件。策略物件改變 context 物件的執行演算法。
介紹
**意圖:**定義一系列的演算法,把它們一個個封裝起來, 並且使它們可相互替換。
**主要解決:**在有多種演算法相似的情況下,使用 if…else 所帶來的複雜和難以維護。
**何時使用:**一個系統有許多許多類,而區分它們的只是他們直接的行為。
**如何解決:**將這些演算法封裝成一個一個的類,任意地替換。
**關鍵程式碼:**實現同一個介面。
應用例項:
1、諸葛亮的錦囊妙計,每一個錦囊就是一個策略。
2、旅行的出遊方式,選擇騎自行車、坐汽車,每一種旅行方式都是一個策略。
3、JAVA AWT 中的 LayoutManager。
**優點: **1、演算法可以自由切換。 2、避免使用多重條件判斷。 3、擴充套件性良好。
**缺點: **1、策略類會增多。 2、所有策略類都需要對外暴露。
使用場景:
1、如果在一個系統裡面有許多類,它們之間的區別僅在於它們的行為,那麼使用策略模式可以動態地讓一個物件在許多行為中選擇一種行為。
2、一個系統需要動態地在幾種演算法中選擇一種。
3、如果一個物件有很多的行為,如果不用恰當的模式,這些行為就只好使用多重的條件選擇語句來實現。
**注意事項:**如果一個系統的策略多於四個,就需要考慮使用混合模式,解決策略類膨脹的問題。
實現
我們將建立一個定義活動的 Strategy 介面和實現了 Strategy 介面的實體策略類。Context 是一個使用了某種策略的類。
StrategyPatternDemo,我們的演示類使用 Context 和策略物件來演示 Context 在它所配置或使用的策略改變時的行為變化。
using System; namespace 策略模式 { // 步驟 1 //建立一個介面。 public interface Strategy { int doOperation(int num1, int num2); } // 步驟 2 //建立實現介面的實體類。 public class OperationAdd : Strategy { public int doOperation(int num1, int num2) { return num1 + num2; } } public class OperationSubstract : Strategy { public int doOperation(int num1, int num2) { return num1 - num2; } } public class OperationMultiply : Strategy { public int doOperation(int num1, int num2) { return num1 * num2; } } // 步驟 3 //建立 Context 類。 public class Context { private Strategy strategy; public Context(Strategy strategy) { this.strategy = strategy; } public int executeStrategy(int num1, int num2) { return strategy.doOperation(num1, num2); } } // 步驟 4 //使用 Context 來檢視當它改變策略 Strategy 時的行為變化。 public class Program { private static void Main(string[] args) { Context context = new Context(new OperationAdd()); Console.WriteLine("10 + 5 = " + context.executeStrategy(10, 5)); context = new Context(new OperationSubstract()); Console.WriteLine("10 - 5 = " + context.executeStrategy(10, 5)); context = new Context(new OperationMultiply()); Console.WriteLine("10 * 5 = " + context.executeStrategy(10, 5)); Console.ReadKey(); } } }