一弥喉、模式定義
定義:定義一組算法,將每個(gè)算法都封裝起來(lái)例嘱,并且使他們之間可以互換狡逢。
二、模式UML結(jié)構(gòu)
策略模式是對(duì)算法的封裝拼卵,把一系列的算法分別封裝到對(duì)應(yīng)的類中奢浑,并且這些類實(shí)現(xiàn)相同的接口,相互之間可以替換腋腮。在前面說(shuō)過(guò)的行為類模式中雀彼,有一種模式也是關(guān)注對(duì)算法的封裝——模版方法模式壤蚜。
?????對(duì)照類圖可以看到,策略模式與模版方法模式的區(qū)別僅僅是多了一個(gè)單獨(dú)的封裝類Context徊哑,它與模版方法模式的區(qū)別在于:在模版方法模式中袜刷,調(diào)用算法的主體在抽象的父類中,而在策略模式中莺丑,調(diào)用算法的主體則是封裝到了封裝類Context中著蟹,抽象策略Strategy一般是一個(gè)接口,目的只是為了定義規(guī)范梢莽,里面一般不包含邏輯萧豆。
其實(shí),這只是通用實(shí)現(xiàn)昏名,而在實(shí)際編程中炕横,因?yàn)楦鱾€(gè)具體策略實(shí)現(xiàn)類之間難免存在一些相同的邏輯,為了避免重復(fù)的代碼葡粒,我們常常使用抽象類來(lái)?yè)?dān)任Strategy的角色份殿,在里面封裝公共的代碼,因此嗽交,在很多應(yīng)用的場(chǎng)景中卿嘲,在策略模式中一般會(huì)看到模版方法模式的影子。
三夫壁、策略模式的結(jié)構(gòu)
封裝類:也叫上下文拾枣,對(duì)策略進(jìn)行二次封裝,目的是避免高層模塊對(duì)策略的直接調(diào)用盒让。
抽象策略:通常情況下為一個(gè)接口梅肤,當(dāng)各個(gè)實(shí)現(xiàn)類中存在著重復(fù)的邏輯時(shí),則使用抽象類來(lái) 封裝這部分公共的代碼邑茄,此時(shí)姨蝴,策略模式看上去更像是模版方法模式。
具體策略:具體策略角色通常由一組封裝了算法的類來(lái)?yè)?dān)任肺缕,這些類之間可以根據(jù)需要自由替換左医。
四、策略模式的優(yōu)缺點(diǎn)
策略模式的優(yōu)點(diǎn)有:
(1)策略類之間可以自由切換同木,由于策略類實(shí)現(xiàn)自同一個(gè)抽象浮梢,所以他們之間可以自由切換。
(2)易于擴(kuò)展彤路,增加一個(gè)新的策略對(duì)策略模式來(lái)說(shuō)非常容易秕硝,基本上可以在不改變?cè)写a的基礎(chǔ)上進(jìn)行擴(kuò)展。
(3)避免使用多重條件洲尊,如果不使用策略模式远豺,對(duì)于所有的算法奈偏,必須使用條件語(yǔ)句進(jìn)行連接,通過(guò)條件判斷來(lái)決定使用哪一種算法憋飞,在上一篇文章中我們已經(jīng)提到,使用多重條件判斷是非常不容易維護(hù)的姆吭。
策略模式的缺點(diǎn):
(1)維護(hù)各個(gè)策略類會(huì)給開(kāi)發(fā)帶來(lái)額外開(kāi)銷榛做,可能大家在這方面都有經(jīng)驗(yàn):一般來(lái)說(shuō),策略類的數(shù)量超過(guò)5個(gè)内狸,就比較令人頭疼了检眯。
(2)必須對(duì)客戶端(調(diào)用者)暴露所有的策略類,因?yàn)槭褂媚姆N策略是由客戶端來(lái)決定的昆淡,因此锰瘸,客戶端應(yīng)該知道有什么策略,并且了解各種策略之間的區(qū)別昂灵,否則避凝,后果很嚴(yán)重。例如眨补,有一個(gè)排序算法的策略模式管削,提供了快速排序、冒泡排序撑螺、選擇排序這三種算法含思,客戶端在使用這些算法之前,是不是先要明白這三種算法的適用情況甘晤?再比如含潘,客戶端要使用一個(gè)容器,有鏈表實(shí)現(xiàn)的线婚,也有數(shù)組實(shí)現(xiàn)的遏弱,客戶端是不是也要明白鏈表和數(shù)組有什么區(qū)別?就這一點(diǎn)來(lái)說(shuō)是有悖于迪米特法則的塞弊。
五腾窝、適用場(chǎng)景
????做面向?qū)ο笤O(shè)計(jì)的,對(duì)策略模式一定很熟悉居砖,因?yàn)樗鼘?shí)質(zhì)上就是面向?qū)ο笾械睦^承和多態(tài)虹脯,在看完策略模式的通用代碼后,我想奏候,即使之前從來(lái)沒(méi)有聽(tīng)說(shuō)過(guò)策略模式循集,在開(kāi)發(fā)過(guò)程中也一定使用過(guò)它吧?至少在在以下兩種情況下蔗草,大家可以考慮使用策略模式:
幾個(gè)類的主要邏輯相同咒彤,只在部分邏輯的算法和行為上稍有區(qū)別的情況疆柔。
有幾種相似的行為,或者說(shuō)算法镶柱,客戶端需要?jiǎng)討B(tài)地決定使用哪一種旷档,那么可以使用策略模式,將這些算法封裝起來(lái)供客戶端調(diào)用歇拆。
策略模式是一種簡(jiǎn)單常用的模式鞋屈,我們?cè)谶M(jìn)行開(kāi)發(fā)的時(shí)候,會(huì)經(jīng)常有意無(wú)意地使用它故觅,一般來(lái)說(shuō)厂庇,策略模式不會(huì)單獨(dú)使用,跟模版方法模式输吏、工廠模式等混合使用的情況比較多权旷。
六、參考文章