用Swift整理GOF設計模式(二)--模板方法

一、“組件協作”模式

概述:現代軟件專業分工之后的第一個結果是劃分出了框架和應用。而“組件協作”模式通過晚綁定,來實現框架和應用的松耦合,是兩者之間協作的常用模式。

這個思想的典型模式是:Template模板方法、Strategy策略模式、Observer/Event觀察者模式.
ps:這并非表示其他模式就不注重組件協作的問題,只是這三個模式在這個特性上尤為突出。

二、設計動機

在現在的軟件構建的過程中,常常會有穩定的整體結構,但是各個子模塊常常會有頻繁變化的需求,還有可能在軟件構造中,由于不同模塊的不同構造時間,子模塊代碼晚于整體穩定模塊。

三、模式場景

下面展示一段庫和程序開發中的例子:我在Playground中書寫代碼舉例

//庫發開程序員
class Library{
    func step1() -> Void {
        //...
    }
    func step3() -> Void {
        //...
    }  
    func step5() -> Void {
        //...
    }
}
//iOS應用程序開發程序員
class Application{  
    func step2() -> Bool {
        //...
        return true
    }
    func step4() -> Void {
        //...
    }
}

//邏輯代碼
let lib:Library = Library()
let app:Application = Application()
lib.step1()
if (app.step2()) {
    lib.step3()
}
for _ in 0...4 {
    app.step4()
}
lib.step5()

這個例子中展示了開發中iOS開發程序員和庫開發程序員的例子。這里假設了庫代碼和程序開發中的方法先后執行順序的問題。
但是這其中埋藏著一個問題,作為庫開發人員,其實調用庫的邏輯代碼流程一般而言應該由庫開發程序員來設定,它應該是穩定的,不應修改的。所以我們可以嘗試來改寫它。

四、修改設計

現在我們來利用模板方法來進行修改,我們將算法代碼中穩定的部分固定在Library里,而將變化的部分留給子類。于是這里Application繼承于Library。

class Library{   
    func Run(){   
        func step1() -> Void {
            //...
        }
        func step3() -> Void {
            //...
        }        
        func step5() -> Void {
            //...
        }   
  
        step1()
        if (step2()) {
            step3()
        }
        for _ in 0...4 {
            step4()
        }
        step5()    
    } 
    func step2() -> Bool {
        //...
        return true
    }
    func step4() -> Void {
        //...
    }    
}
class Application:Library{
//重載變化的部分
    override func step2() -> Bool {
        //...
        return true
    }
    override func step4() -> Void {
        //...
    }
}
//主邏輯
let app:Application = Application()
app.Run()

不得不承認,這個模式看上去十分簡單,這個模式的存在依賴于面向對象的特點,但往往很多人在書寫代碼的時候,雖然使用面向對象語言,但是設計思想往往是結構化的。
如果step1是變化的,你就可以重載step1方法。關鍵是抓住一個算法中變化的部分。假如step1-step5全都是不變化的,那么沒有一個設計模式可以適應這種變化。
設計模式的存在是依賴于穩定點。
換言之,假如step1-step5全都是不變的,那么也不需要設計模式了。


46733935-09B3-4772-823C-A39CB76A34BA.png

模板方法模式的思想是定義一個穩定的算法骨架,而將變化的部分放置到子類中去。子類可以通過override來重寫變化的部分。這樣達到設計模式復用的目的。
需要注意的是,這個模式的存在依賴run(穩定)的存在,必須有一部分是穩定的,如果run函數出現了變化,這個模式就是失敗的。所以我們必須找出不變的部分。


AF405227-5C25-4A50-9538-9321088383BF.png

第一種寫法為早綁定,第二種寫法為晚綁定。
就如上圖所示,一般而言,庫開發往往都早于我們App開發,晚開發的東西調用早開發的東西即為早綁定,這種思想其實十分正常,c語言時期都默認這種做法。
但當有了面向對象特性之后,我們就可以實現晚綁定。

五、模板方法的弊端

模板方法在面向對象語言中使用非常多,但是它也有它自己的弊端。
因為把主要邏輯都封在了父類中,例子中的iOS App開發人員或者說對于繼承父類的子類,只需要重載某些步驟,甚至一句調用代碼都不用寫,應用程序就可以直接跑起來。
但這樣,上層開發人員(此處指實現子類的程序員)就會只知道用法,卻不清楚整個實現邏輯的感覺。因為整個邏輯骨架都封裝在父類中。
所以作為應用程序app開發人員,有時也有必要去了解一下庫的實現。

六、要點總結

1.模板方法是非常簡單基礎的設計模式,幾乎每一個面向對象開發者都使用過。用最簡單的結構,實現代碼復用。
2.需要靈活對待變化點,不要讓"你調用我,而是讓我調用你",理解早綁定和晚綁定。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,572評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,071評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,409評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,569評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,360評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,895評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,979評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,123評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,643評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,559評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,742評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,250評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,981評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,363評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,622評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,354評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,707評論 2 370

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,776評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,593評論 25 707
  • 1 場景問題# 1.1 登錄控制## 幾乎所有的應用系統,都需要系統登錄控制的功能,有些系統甚至有多個登錄控制的功...
    七寸知架構閱讀 1,992評論 3 53
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,707評論 18 399
  • 詞:董書利 你走了人住心里,閉上眼容顏都是你那揮之不去 的從前占滿我的整個 夜里 睜眼你轉身離去再也觸碰不到你于是...
    星巢文化閱讀 218評論 0 1