????????小弟不才, 但又喜歡分享一些自己知道的小知識, so 斗膽寫下 iOS 常用設計模式的實用和對其的見解. 如果有錯的地方請聯系我 QQ: 573880506, 不勝感激(畢竟程序員, 標點符號都用的英文狀態(tài)下的, 不喜勿噴請見諒)
1.設計模式的由來?
? ? ? ? 針對特定的問題, 前輩總結出來的一種固定模式, 就好像你寫作文每一個段落都會空兩個格一樣.
?2. 設計模式的優(yōu)點
????????①. 使項目結構編變得更清晰.
? ? ? ? ②. 便于維護.(ps: 各設計模式優(yōu)缺點會在各自專題中會進行詳細的描述)
3. 設計模式的基本原則
? ? ? ? ①. 開閉原則 (Open Closed Principle,OCP):?對模塊擴展開放, 對修改關閉, 給我的感覺就是 .m 里面的實現代碼盡量不要去做修改, 對這個類進行拓展而不是修改. 我們正常開發(fā)時, 總遇到各式各樣的修改, 我會做的是注釋掉這段代碼, 再重寫一份, 其實也算是變相地拓展接口.
????????②.?里氏替換原則 (Liskov Substitution Principle ,LSP): 任何類可以出現的地方,子類一定可以出現,子類跟父類可以相互替換,子類可以用父類所有的方法(下面會舉個例子). 這個比較不容易理解, 百度一搜通篇一律, 說得特別難懂, 我覺得里氏替換原則和多態(tài)有一些相類似, 都是子類繼承自父類, 子類可以拓展接口, 不同的是: 里氏替換原則盡量不要重寫父類的方法, 而多態(tài)可以重寫父類的方法.?
? ? ? ? 舉個栗子: 有一個 Animals 類作為父類, Dog 類作為 Animals 類的子類, 他們都有一個方法 - (BOOL)isLikeIt; 返回值是 YES , 當你的 controller 導入了 Animals 并調用了這個方法是你喜歡動物, 當你突然想換成 Dog 類時, 正常這個方法的返回值應該是 YES, 如果你的 Dog 類繼承 Animals 類時修改這個方法為 NO, 很有可能你的 controller 會死掉, 所以我們盡量不要改動父類繼承過來的方法, 而要去拓展接口才能做到賦值兼容, 這也符合上面的開閉原則.
? ? ? ? ③.?依賴倒轉原則 (DependencyInversion Principle,DIP):?抽象不依賴于細節(jié), 細節(jié)依賴于抽象. 父類高度抽象時, 子類才更不容易出現問題. 雜貨部 CEO 會說: "我們公司要盈利", 廁紙經理會說: "我們要通過賣廁紙盈利", 食品經理會說:"我們要通過賣辣條盈利", 這才符合邏輯, 反面教材見下面的栗子:
????????舉個栗子: 有一個 Paper 類作為基類, 其有一個方法 - (void)used; 有一個 Money 類繼承自 Paper, 有一個 ToiletPaper(廁紙) 繼承自 Paper, 如果 Paper 類中的 used NSLog 了一句話 @"擦屁股", Money 調用 used 時就會出問題, 除非你希望用錢來擦屁股.
????????④.?接口隔離原則 (InterfaceSegregationPrinciple,ISP):?接口里面只做必要的事情, 不做其他相關的事情.?
????????⑤.?合成/聚合復用原則 (Composite/ Aggregate Reuse Principle, CARP):?在一個新的對象里面使用一些已有的對象频蛔,使之成為新對象的一部分. 用一個圖大家就明白了: 錢包類想調用 Money 的 used 方法, 不用繼承 Money 類, 直接導入形成個新類即可.
????????⑥.?最小知識原則 (Principle of Least Knowledge, PLK):?兩個類沒有彼此直接通信, 而是使用另一個類來通信. 我們平時用的 MVC 其實就是遵循了這一原則.
????????⑦.?單一職責原則 (Single responsibility principle,SRP): 一個類只負責一種領域, 網絡請求類去做視頻渲染, 讓視頻渲染類進行網絡請求
4. 23 中設計模式的分類
????????①. 創(chuàng)建型模式(5 種): 單例模式, 抽象工廠模式, 建造者模式, 原型模式, 工廠模式.
????????②. 并發(fā)設計模式(7 種): 代理模式, 組合模式, 橋接模式, 享元模式, 外觀模式, 裝飾模式, 適配器模式.
????????③. 框架級別的設計模式(11 種): 觀察者模式, 訪問者模式, 中介者模式, 解釋器模式, 策略模式, 迭代器模式, 命令模式, 狀態(tài)模式, 備忘錄模式, 模板方法模式, 責任鏈模式.
5. 小結
????????這里先簡單介紹一下設計模式的相關小知識, 之后會有各設計模式單獨的文章來詳細描述各設計模式的的優(yōu)缺點, demo 等相關知識.
? ? ? ? 使用設計模式和非使用設計模式給我的感覺就像是: 鳥巢 vs 普通樓房, 雖然我總是想不起來使用設計模式, 因為我做的也是普通樓房, 當我們水平達到一定程度之時, 這些設計模式使用起來也就得心應手了.
? ??????最后, 我想強調一句: 不要為了使用設計模式而去強行使用設計模式.
這里是傳送門呦: