再學設計模式

1.builder模式

優點

實現了產品構建和產品表現的分離。
這句話的意思是客戶端構建產品的時候只會調用builder的設置方法,最后構建出一個產品。并沒有直接調用產品類的設置屬性方法,或者直接為產品的屬性賦值。
我們在調用的時候并不需要關心產品類的具體屬性和方法,可以比較容易的改變產品類的內部表示。
另外的一個好處是,builder提供了產品類比較好的一致性。因為如果直接構造產品
類的話,我們可以在任何時候,任何線程對產品類做set操作,這就導致了一些bug很難找到。

2.adpter模式

類適配器

類適配器模式.png

類的適配器模式把適配的類的api轉換成為目標類的API。
利用繼承的方式重新定義Adptee的部分行為,達到適配的目的。
因為是繼承關系,所以對于變化,可以通過新增一個繼承,改變類適配器的行為。

對象適配器

對象適配器模式.png

與類的適配器模式一樣,對象的適配器模式把適配的類的API轉換成為目標類的API,與類的適配器模式不同的是,對象適配器不是使用繼承關系連接到Adaptee類,而是使用委派關系連接到Adptee類。

對于對象適配器,一個適配器可以把不同的源適配到同一個目標。
對于對象適配器使用對象組合的方式,是動態組合的方式。
對于對象適配器,要重新定義Adptee的行為比較困難。因為不像類適配器,增加一個繼承類就可以了。

listview的緩存

3.裝飾器模式

裝飾模式.png

概念

動態地給一個兌現更加一些額外的職責,就增加對象功能來說,裝飾模式比生成子類實現更為靈活。

比繼承的優點

不會產生很多的子類。對客戶端透明,減少耦合度。

使用場景:

1.在不影響其他對象的情況下,以動態、透明的方式給單個對象添加職責。
2.當不能采用繼承方式對系統進行擴展或者采用繼承不利于系統擴展和維護
時,可以使用裝飾模式。比如有些Final類。

4.外觀模式

定義

外觀模式的主要目的在于讓外部減少與子系統內部多個模塊的交互,從而讓外部能夠更簡單的使用子系統。它負責把客戶端的請求轉發給子系統內部的各個模塊進行處理。

使用場景

1.當你要為一個復雜子系統提供一個簡單接口時。
2.客戶程序與抽象類的實現部分之間存在著很大的依賴性。
3.當你需要構建一個層次結構的子系統時候

5.組合模式

組合設計模式.png

定義

將對象以樹形結構組織起來,以達成“部分-整體”的層次結構,使得客戶以一致的方式處理單個對象以及對象的組合。

優點

1.高層模塊調用簡單
2.節點自由增加

實例說明

該例子生動的說明了組合方式的好處
https://www.cnblogs.com/lfxiao/p/6816026.html

https://www.cnblogs.com/snaildev/p/7647190.html

android中的應用

android中的view采用了組合模式

6.策略模式

策略模式.png

概念

定義一系列的算法,把它們一個個封裝起來,并且使他們可相互替換,本模式使得算法可獨立于使用它的客戶而變化。用來替代if else和switch方式

使用場景

一個類定義了多種行為,并且這些行為在這個類的方法中以多個條件語句的形式出現,那么可以使用策略模式來避免類中使用大量的條件語句。

優點

1.上下文(Context)和具體策略(ConcreteStragety)是松耦合關系。因為上下文
持有的是抽象的策略類。
2.滿足開閉原則。

andorid中的應用

1.Volley中對于httpstack使用策略模式

7.模板方法模式

模板設計模式.png

定義

模板方法是通過定義一個算法框架,而將算法中的步驟延遲到子類,子類就可以特定的算法。

使用場景

1.多個子類有公有方法,并且邏輯及基本相同
2.重構時經常使用,將相同的代碼抽取到父類中。

在android應用

AysncTask,Activity

8.觀察者設計模式

觀察者模式.png

概念

定義對象之間一種一對多依賴關系,使得每當一個對象狀態發生改變時,其相關依賴對象皆得到通知并被自動更新。

andorid中的應用

1.回調模式
2.listview中的notifyChanged

9.責任鏈設計模式

責任鏈模式.png

概念

是一個請求有多個對象來處理,這些對象是一條鏈,但具體由哪個對象來處理,根據條件判斷來確定,如果不能處理會傳遞給該鏈中的下一個對象,直到有對象處理它為止。

使用場景

1.有多個對象可以處理同一個請求,具體哪個對象處理該請請求待運行時刻再確
定。
2.在不明確指定接受者的情況下,向多個對象中的一個提交一個請求。
3.可動態指定一組對象處理請求,客戶端可以動態創建職責鏈來處理請求。

在android中的應用

1.try catch
2.ordered broadcast
3.viewgroup事件傳遞

易混淆的設計模式

適配器模式和裝飾器模式

裝飾器與適配器都有一個別名叫做 包裝模式(Wrapper),它們看似都是起到包裝一個類或對象的作用,但是使用它們的設計目的很不一一樣。
適配器模式的意義是要將一個接口轉變成另一個接口,它的目的是通過改變接口來達到重復使用的目的。 所以從UML中看出,adpter類必須繼承一個已有的接口,從而保證符合目標類的接口,而不必關心被適配類adptee的接口如何
而裝飾器模式不是要改變被裝飾對象的接口,而是恰恰要保持原有的接口,但是增強原有對象的功能,或者改變原有對象的處理方式而提升性能。所以從UML圖可以看出,裝飾者和被裝飾者都必須繼承于同一個父類,從而保證接口的相同

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

推薦閱讀更多精彩內容

  • 設計模式基本原則 開放-封閉原則(OCP),是說軟件實體(類、模塊、函數等等)應該可以拓展,但是不可修改。開-閉原...
    西山薄涼閱讀 3,833評論 3 14
  • 創建型模式 工廠模式 工廠模式(Factory Pattern)是 Java 中最常用的設計模式之一。這種類型的設...
    隔墻送來秋千影閱讀 2,681評論 0 11
  • 創建型模式 工廠模式 工廠模式(Factory Pattern)是 Java 中最常用的設計模式之一。這種類型的設...
    liuyang7519閱讀 332評論 0 2
  • Swift1> Swift和OC的區別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴謹 對...
    cosWriter閱讀 11,121評論 1 32
  • 0.提前說明 模式選擇的方法1)模式的功能——看是否能解決問題2)模式的本質——看模式是否主要用來解決這類問題3)...
    王偵閱讀 1,073評論 0 1