日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

算法族的集中管理——策略模式

發(fā)布時(shí)間:2025/3/14 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法族的集中管理——策略模式 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

策略模式是指對(duì)一系列的算法定義,并將每一個(gè)算法封裝起來(lái),而且使它們還可以相互替換。策略模式讓算法獨(dú)立于使用它的客戶而獨(dú)立變化。

我們正好可以使用策略模式加適配器模式來(lái)將查找算法的調(diào)用重新架構(gòu)。

分角色

  • 環(huán)境類Context,直接暴露給客戶端使用的類。
  • 策略類Strategy,是一個(gè)抽象類,用于統(tǒng)籌策略
  • 具體策略類,繼承自Strategy,有自己的實(shí)現(xiàn)方法。
  • 應(yīng)用

    為了學(xué)習(xí)策略模式,我們將查找算法中的BST和RedBlackBST兩個(gè)類作為研究素材,研究設(shè)計(jì)模式肯定是不能修改原有代碼,也就是說(shuō)BST和RedBlackBST不會(huì)做任何修改,在此基礎(chǔ)上,我們使用適配器模式將其封裝取出

    • BSTAdapter
    • RedBlackBSTAdapter

    下面展示BSTAdapter的代碼,RedBlackAdapter與它相似。

    package pattern.strategy;import algorithms.search.ST; import algorithms.search.STImpl.BST;public class BSTAdapter extends Strategy {@Overridepublic void algorithm() {logger.info(this.getClass().getName());ST<Integer, String> st;st = new ST<Integer, String>(new BST<Integer, String>());testST(st);}}

    然后貼上Strategy的代碼,省略了一些與模式無(wú)關(guān)的內(nèi)容。

    public abstract class Strategy {protected static final Logger logger = LogManager.getLogger();public abstract void algorithm();// 核心抽象方法protected void testST(ST<Integer, String> sst) {...} }

    最后是Context的代碼

    package pattern.strategy;public class Context {private Strategy strategy;public void setStrategy(Strategy strategy) {this.strategy = strategy;}public void testSTStrategy() {strategy.algorithm();} }

    客戶端的調(diào)用方法

    package pattern.strategy;import org.junit.Test;public class StrategyClient {@Testpublic void testStrategy() {Context context = new Context();context.setStrategy(new RedBlackBSTAdapter());// 運(yùn)行時(shí)指定具體類型context.testSTStrategy();context.setStrategy(new BSTAdapter());// 運(yùn)行時(shí)指定具體類型context.testSTStrategy();} }

    輸出:

    11:22:50[algorithm]: pattern.strategy.RedBlackBSTAdapter 11:22:50[testST]: 總耗時(shí):69ms 11:22:50[algorithm]: pattern.strategy.BSTAdapter 11:22:51[testST]: 總耗時(shí):88ms

    下面給出類圖

    策略模式總結(jié)

  • 我們上面使用的策略模式和適配器模式的聯(lián)通使得完全沒(méi)有對(duì)BST和RedBlackBST做任何改變即可將它們套用到新的架構(gòu)之中,所以策略模式是對(duì)“開閉原則”的完美實(shí)現(xiàn)。
  • 策略模式提供了管理相關(guān)的算法族的辦法。策略類的等級(jí)結(jié)構(gòu)定義了一個(gè)算法或行為族,恰當(dāng)使用繼承可以把公共的代碼移到抽象策略類中,從而避免重復(fù)的代碼。
  • 缺點(diǎn):

    以上展示的策略模式仍舊處于初級(jí)階段,具體算法均需要通過(guò)繼承來(lái)實(shí)現(xiàn),可以作為研究學(xué)習(xí)使用,仍然存在一些問(wèn)題,例如對(duì)具體策略類的管理,如果使用場(chǎng)景不當(dāng),可能每次都要新建一個(gè)具體策略類,因此我們這里將其與適配器模式聯(lián)用有效地避免了這一點(diǎn)。

    轉(zhuǎn)載于:https://www.cnblogs.com/Evsward/p/Strategy.html

    總結(jié)

    以上是生活随笔為你收集整理的算法族的集中管理——策略模式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。