當我們寫**時總會遇到一種情況,就是我們會有很多的選擇,由此衍生出很多的if…else,或者case。如果每個條件語句中包含了乙個簡單的邏輯,那還比較容易處理;但如果在乙個條件語句中又包含了多個條件語句,就會使得**變得臃腫,維護的成本也會加大,這顯然違背了開放封閉原則。
若是邏輯簡單的話還好,邏輯複雜的話會有較為明顯的問題:public void pay(string paytype) else if ("aili".equals(paytype)) else if ("yinhangcard".equals(paytype)) else
}
if...else...多層巢狀,如果內部有更多的邏輯,巢狀會非常複雜;
如果又新增了更多的支付方式的話,pay的**還要修改,無法對程式進行很好的擴充套件。
因此為了較好的擴充套件程式,我們應該針對介面程式設計,而不是針對實現程式設計。那麼我們使用策略模式來解決上述寫法所面臨的問題:
行為介面:
public inte***ce payment
具體的支付方式:
public class weixinpay implements payment
}
外界和具體策略進行連線的設定類(引數是具體的實現):public class alipay implements payment
}
用來操作策略的上下文環境,起到承上啟下的作用,遮蔽高層模組對策略、演算法的直接訪問,在這裡我們需要知道針對不同的情況使用哪種策略行為,這裡就是原來的巢狀的多層if...else...的地方,現在我們只需要在不同的情況下使用不同的策略即可:public class shopcart
public void pay(string price)
}
採用策略模式後,當新增支付方式時,只需要實現乙個繼承payment介面的類即可,shopcart類不需要做任何改動,做到了對修改關閉,對擴充套件開放的原則,同時也做到針對介面程式設計,而不是針對實現程式設計的設計原則。其實真正的專案中,shopcart是個很複雜的類,裡面會有很多業務邏輯,在新增業務不改動舊邏輯,會增加專案的穩定性,也減少測試的工作投入。shopcart shopcartweinxin = new shopcart(new weixinpay());
shopcartweinxin.pay("22");
shopcart shopcartali = new shopcart(new alipay());
shopcartali.pay("33");
原始碼中所使用策略模式:
乙個整體的簡單示例:
inte***ce mathalgorithm
class mathadd implements mathalgorithm
}class mathsubstract implements mathalgorithm
}class mathmultiply implements mathalgorithm
}class mathcontext
public int execute(int num1, int num2)
}public class main
}
倒車雷達原理篇
往後倒一點,再往後,打方向盤,打多了,回一點再倒,好,停!相信一般的車主在停車場泊位時,都會遇到車輛保管員的 熱情招呼 車技純熟的倒 也與人工提示配合默契 車技一般 方向感較差的,就經常使負責指揮的那位人士高度緊張,脾氣急躁的還少不了擠兌車主幾句。可是,並不是所有車主都有幸得到 人工倒車指引,比如說...
iOS知識原理篇
weak策略表明該屬性定義了一種 非擁有關係 nonowning relationship 為這種屬性設定新值時,設定方法既不保留新值,也不釋放舊值。此特質同assign類似 然而在屬性所指的物件遭到摧毀時,屬性值也會清空 nil out runtime對註冊的類,會進行布局,會將 weak 物件放...
MongoDB分片原理篇
mongodb目前3大核心優勢 靈活模式 高可用性 可擴充套件性 通過json文件來實現靈活模式,通過複製集來保證高可用,通過sharded cluster來保證可擴充套件性。何時使用分片技術 儲存容量需求超出單機磁碟容量 活躍的資料集超出單機記憶體容量,導致很多請求都要從磁碟讀取資料,影響效能 寫...