1.builder模式
優(yōu)點(diǎn)
實(shí)現(xiàn)了產(chǎn)品構(gòu)建和產(chǎn)品表現(xiàn)的分離。
這句話的意思是客戶端構(gòu)建產(chǎn)品的時(shí)候只會(huì)調(diào)用builder的設(shè)置方法捐顷,最后構(gòu)建出一個(gè)產(chǎn)品。并沒(méi)有直接調(diào)用產(chǎn)品類(lèi)的設(shè)置屬性方法僻孝,或者直接為產(chǎn)品的屬性賦值。
我們?cè)谡{(diào)用的時(shí)候并不需要關(guān)心產(chǎn)品類(lèi)的具體屬性和方法堡称,可以比較容易的改變產(chǎn)品類(lèi)的內(nèi)部表示。
另外的一個(gè)好處是艺演,builder提供了產(chǎn)品類(lèi)比較好的一致性却紧。因?yàn)槿绻苯訕?gòu)造產(chǎn)品
類(lèi)的話,我們可以在任何時(shí)候胎撤,任何線程對(duì)產(chǎn)品類(lèi)做set操作晓殊,這就導(dǎo)致了一些bug很難找到。
2.adpter模式
類(lèi)適配器
類(lèi)的適配器模式把適配的類(lèi)的api轉(zhuǎn)換成為目標(biāo)類(lèi)的API哩照。
利用繼承的方式重新定義Adptee的部分行為挺物,達(dá)到適配的目的。
因?yàn)槭抢^承關(guān)系飘弧,所以對(duì)于變化,可以通過(guò)新增一個(gè)繼承砚著,改變類(lèi)適配器的行為次伶。
對(duì)象適配器
與類(lèi)的適配器模式一樣,對(duì)象的適配器模式把適配的類(lèi)的API轉(zhuǎn)換成為目標(biāo)類(lèi)的API稽穆,與類(lèi)的適配器模式不同的是冠王,對(duì)象適配器不是使用繼承關(guān)系連接到Adaptee類(lèi),而是使用委派關(guān)系連接到Adptee類(lèi)舌镶。
對(duì)于對(duì)象適配器柱彻,一個(gè)適配器可以把不同的源適配到同一個(gè)目標(biāo)。
對(duì)于對(duì)象適配器使用對(duì)象組合的方式餐胀,是動(dòng)態(tài)組合的方式哟楷。
對(duì)于對(duì)象適配器,要重新定義Adptee的行為比較困難否灾。因?yàn)椴幌耦?lèi)適配器卖擅,增加一個(gè)繼承類(lèi)就可以了。
listview的緩存
3.裝飾器模式
概念
動(dòng)態(tài)地給一個(gè)兌現(xiàn)更加一些額外的職責(zé)墨技,就增加對(duì)象功能來(lái)說(shuō)惩阶,裝飾模式比生成子類(lèi)實(shí)現(xiàn)更為靈活。
比繼承的優(yōu)點(diǎn)
不會(huì)產(chǎn)生很多的子類(lèi)扣汪。對(duì)客戶端透明断楷,減少耦合度。
使用場(chǎng)景:
1.在不影響其他對(duì)象的情況下崭别,以動(dòng)態(tài)冬筒、透明的方式給單個(gè)對(duì)象添加職責(zé)统刮。
2.當(dāng)不能采用繼承方式對(duì)系統(tǒng)進(jìn)行擴(kuò)展或者采用繼承不利于系統(tǒng)擴(kuò)展和維護(hù)
時(shí),可以使用裝飾模式账千。比如有些Final類(lèi)侥蒙。
4.外觀模式
定義
外觀模式的主要目的在于讓外部減少與子系統(tǒng)內(nèi)部多個(gè)模塊的交互,從而讓外部能夠更簡(jiǎn)單的使用子系統(tǒng)匀奏。它負(fù)責(zé)把客戶端的請(qǐng)求轉(zhuǎn)發(fā)給子系統(tǒng)內(nèi)部的各個(gè)模塊進(jìn)行處理鞭衩。
使用場(chǎng)景
1.當(dāng)你要為一個(gè)復(fù)雜子系統(tǒng)提供一個(gè)簡(jiǎn)單接口時(shí)。
2.客戶程序與抽象類(lèi)的實(shí)現(xiàn)部分之間存在著很大的依賴性娃善。
3.當(dāng)你需要構(gòu)建一個(gè)層次結(jié)構(gòu)的子系統(tǒng)時(shí)候
5.組合模式
定義
將對(duì)象以樹(shù)形結(jié)構(gòu)組織起來(lái)论衍,以達(dá)成“部分-整體”的層次結(jié)構(gòu),使得客戶以一致的方式處理單個(gè)對(duì)象以及對(duì)象的組合聚磺。
優(yōu)點(diǎn)
1.高層模塊調(diào)用簡(jiǎn)單
2.節(jié)點(diǎn)自由增加
實(shí)例說(shuō)明
該例子生動(dòng)的說(shuō)明了組合方式的好處
https://www.cnblogs.com/lfxiao/p/6816026.html
https://www.cnblogs.com/snaildev/p/7647190.html
android中的應(yīng)用
android中的view采用了組合模式
6.策略模式
概念
定義一系列的算法坯台,把它們一個(gè)個(gè)封裝起來(lái),并且使他們可相互替換瘫寝,本模式使得算法可獨(dú)立于使用它的客戶而變化蜒蕾。用來(lái)替代if else和switch方式
使用場(chǎng)景
一個(gè)類(lèi)定義了多種行為,并且這些行為在這個(gè)類(lèi)的方法中以多個(gè)條件語(yǔ)句的形式出現(xiàn)焕阿,那么可以使用策略模式來(lái)避免類(lèi)中使用大量的條件語(yǔ)句咪啡。
優(yōu)點(diǎn)
1.上下文(Context)和具體策略(ConcreteStragety)是松耦合關(guān)系。因?yàn)樯舷挛?br>
持有的是抽象的策略類(lèi)暮屡。
2.滿足開(kāi)閉原則撤摸。
andorid中的應(yīng)用
1.Volley中對(duì)于httpstack使用策略模式
7.模板方法模式
定義
模板方法是通過(guò)定義一個(gè)算法框架,而將算法中的步驟延遲到子類(lèi)褒纲,子類(lèi)就可以特定的算法准夷。
使用場(chǎng)景
1.多個(gè)子類(lèi)有公有方法,并且邏輯及基本相同
2.重構(gòu)時(shí)經(jīng)常使用莺掠,將相同的代碼抽取到父類(lèi)中衫嵌。
在android應(yīng)用
AysncTask,Activity
8.觀察者設(shè)計(jì)模式
概念
定義對(duì)象之間一種一對(duì)多依賴關(guān)系汁蝶,使得每當(dāng)一個(gè)對(duì)象狀態(tài)發(fā)生改變時(shí)渐扮,其相關(guān)依賴對(duì)象皆得到通知并被自動(dòng)更新。
andorid中的應(yīng)用
1.回調(diào)模式
2.listview中的notifyChanged
9.責(zé)任鏈設(shè)計(jì)模式
概念
是一個(gè)請(qǐng)求有多個(gè)對(duì)象來(lái)處理掖棉,這些對(duì)象是一條鏈墓律,但具體由哪個(gè)對(duì)象來(lái)處理,根據(jù)條件判斷來(lái)確定幔亥,如果不能處理會(huì)傳遞給該鏈中的下一個(gè)對(duì)象耻讽,直到有對(duì)象處理它為止。
使用場(chǎng)景
1.有多個(gè)對(duì)象可以處理同一個(gè)請(qǐng)求帕棉,具體哪個(gè)對(duì)象處理該請(qǐng)請(qǐng)求待運(yùn)行時(shí)刻再確
定针肥。
2.在不明確指定接受者的情況下饼记,向多個(gè)對(duì)象中的一個(gè)提交一個(gè)請(qǐng)求。
3.可動(dòng)態(tài)指定一組對(duì)象處理請(qǐng)求慰枕,客戶端可以動(dòng)態(tài)創(chuàng)建職責(zé)鏈來(lái)處理請(qǐng)求具则。
在android中的應(yīng)用
1.try catch
2.ordered broadcast
3.viewgroup事件傳遞
易混淆的設(shè)計(jì)模式
適配器模式和裝飾器模式
裝飾器與適配器都有一個(gè)別名叫做 包裝模式(Wrapper),它們看似都是起到包裝一個(gè)類(lèi)或?qū)ο蟮淖饔镁甙铮鞘褂盟鼈兊?strong>設(shè)計(jì)目的很不一一樣博肋。
適配器模式的意義是要將一個(gè)接口轉(zhuǎn)變成另一個(gè)接口,它的目的是通過(guò)改變接口來(lái)達(dá)到重復(fù)使用的目的蜂厅。 所以從UML中看出匪凡,adpter類(lèi)必須繼承一個(gè)已有的接口,從而保證符合目標(biāo)類(lèi)的接口掘猿,而不必關(guān)心被適配類(lèi)adptee的接口如何
而裝飾器模式不是要改變被裝飾對(duì)象的接口病游,而是恰恰要保持原有的接口,但是增強(qiáng)原有對(duì)象的功能稠通,或者改變?cè)袑?duì)象的處理方式而提升性能衬衬。所以從UML圖可以看出,裝飾者和被裝飾者都必須繼承于同一個(gè)父類(lèi)采记,從而保證接口的相同佣耐。