引子
最近在設(shè)計(jì)廣告的SDK齿梁,對(duì)一些模式進(jìn)行了探究吊洼。這里根據(jù)實(shí)際的問(wèn)題金顿,從策略模式做出一個(gè)總結(jié)资溃。
需求
廣告模塊是公司的變現(xiàn)模塊舟陆,非常重要缎罢,目前公司iOS這塊有十來(lái)個(gè)APP一屋。廣告模塊承擔(dān)了從第三方SDK或者直投拿廣告然后以返回廣告數(shù)據(jù)到APP的中介作用擎值。目前是要把這個(gè)模塊徹底抽出來(lái)辈赋,做成SDK鲫忍。
需求分析
功能看起來(lái)沒(méi)有多復(fù)雜,只是數(shù)據(jù)的請(qǐng)求和回調(diào)钥屈。然而悟民,這個(gè)架構(gòu)的設(shè)計(jì)上就有一些坑點(diǎn)。
- 首先就是當(dāng)前我們接入的第三方SDK 只有兩個(gè)篷就,但是射亏,幾乎可以確定的是,后期會(huì)增加竭业。
- 然后智润,由于廣告模塊的重要性,拉取物料失敗后要有個(gè)"補(bǔ)余"操作未辆。這個(gè)"補(bǔ)余"策略窟绷。
策略模式的引入
我們集成SDK 本質(zhì)的作用是拉取廣告數(shù)據(jù),而我們的目的是實(shí)現(xiàn)一系列第三方SDK的接入咐柜,并且可以在第三方SDK之間進(jìn)行切換兼蜈,無(wú)論加多少,我們都可以不修改之前的代碼拙友,只是擴(kuò)展为狸。這就是開(kāi)閉原則。這里就需要用到一個(gè)設(shè)計(jì)模式——策略模式遗契。
策略模式
引用一個(gè)流傳特別廣泛的圖
在strategy中有一系列的協(xié)議方法實(shí)現(xiàn)钥平,在不同的策略中有不同的實(shí)現(xiàn),實(shí)際上,context中保存了策略的指針涉瘾,策略就是由這個(gè)指針來(lái)選擇的〗堇迹可以看到立叛,strategyA,strategyB贡茅,strategyC 實(shí)現(xiàn)了同樣的算法秘蛇,我們可以在三個(gè)策略之間隨意的切換。再增加一個(gè)strategyD的話也只是一個(gè)擴(kuò)展而已顶考,并沒(méi)有修改其他組件的代碼赁还。這里的算法如果有需要的話,還可以復(fù)用驹沿,因?yàn)樗鼈兪仟?dú)立的艘策。
策略模式的使用
由于具體的代碼還沒(méi)有成型,在這里只貼出一部分的簡(jiǎn)易的代碼渊季。Context需要連接三個(gè)SDK:A朋蔫、B、C却汉,中的一個(gè)驯妄,SDK在目錄中的FLASDK,F(xiàn)LBSDK,FLCSDK類(lèi)中集成合砂,而這三個(gè)類(lèi)實(shí)現(xiàn)了FLSDKDelegate中的協(xié)議方法青扔。無(wú)論中間代碼實(shí)現(xiàn)是什么,都實(shí)現(xiàn)了方法getSDKVersion翩伪,這里微猖,外界就不關(guān)心你怎么實(shí)現(xiàn)的,集成的那個(gè)SDK幻工,只需要調(diào)用這個(gè)方法就可以拿到所需要的數(shù)據(jù)励两。
總結(jié)
這樣以來(lái),無(wú)論以后我們要接入多少個(gè)第三方的SDK囊颅,只要在增加一個(gè)strategyX当悔,并在里面實(shí)現(xiàn)了數(shù)據(jù)請(qǐng)求的接口,就可以調(diào)用了踢代。擴(kuò)展性非常好盲憎。
備注:剛開(kāi)始寫(xiě)文章,邏輯不是很順暢胳挎。有人看的話饼疙,并且看出問(wèn)題的話,請(qǐng)不吝指正慕爬,多謝窑眯。