轉(zhuǎn)載 Doing
設(shè)計(jì)模式的六大原則
開閉原則:模塊應(yīng)盡量在不修改原代碼(閉)的情況下進(jìn)行擴(kuò)展(開)。即在程序需要進(jìn)行拓展的時(shí)候测蘑,不能去修改原有的代碼,實(shí)現(xiàn)一個(gè)熱插拔的效果。
里氏代換原則:如果調(diào)用的是父類的話湾笛,那么換成子類也完全可以運(yùn)行。 派生類能夠在基類的基礎(chǔ)上增加新的行為闰歪。只有當(dāng)派生類可以替換掉基類嚎研,且軟件單位的功能不受到影響時(shí),基類才能真正被復(fù)用库倘。實(shí)現(xiàn)開閉原則的關(guān)鍵步驟就是抽象化临扮,而基類與子類的繼承關(guān)系就是抽象化的具體實(shí)現(xiàn),所以里氏代換原則是對(duì)實(shí)現(xiàn)抽象化的具體步驟的規(guī)范教翩。
依賴倒置原則:1杆勇、高層次的模塊不應(yīng)該依賴于低層次的模塊,他們都應(yīng)該依賴于抽象饱亿。2蚜退、抽象不應(yīng)該依賴于具體實(shí)現(xiàn),具體實(shí)現(xiàn)應(yīng)該依賴于抽象彪笼。要求對(duì)抽象/接口進(jìn)行編程钻注,不要對(duì)實(shí)現(xiàn)進(jìn)行編程,這樣就降低了客戶與實(shí)現(xiàn)模塊間的耦合配猫。
接口隔離原則:每一個(gè)接口應(yīng)該是一種角色幅恋,不干不該干的事,該干的事都要干泵肄。降低類之間的耦合度捆交。
合成復(fù)用原則:要盡量使用組合/ 聚合,盡量不要使用繼承腐巢。只有“Is - A” 關(guān)系才符合繼承關(guān)系品追,“Has- A” 關(guān)系應(yīng)當(dāng)使用聚合來描述。
最少知識(shí)原則:一個(gè)對(duì)象應(yīng)對(duì)其它對(duì)象有盡可能少的了解系忙。即一個(gè)實(shí)體應(yīng)當(dāng)盡量少地與其他實(shí)體之間發(fā)生相互作用诵盼,使得系統(tǒng)功能模塊相對(duì)獨(dú)立。
創(chuàng)建型模式
這些設(shè)計(jì)模式提供了一種在創(chuàng)建對(duì)象的同時(shí)隱藏創(chuàng)建邏輯的方式,而不是使用新的運(yùn)算符直接實(shí)例化對(duì)象风宁。這使得程序在判斷針對(duì)某個(gè)給定實(shí)例需要?jiǎng)?chuàng)建哪些對(duì)象時(shí)更加靈活洁墙。
工廠模式與抽象工廠模式 **(Factory Pattern)(Abstract Factory Pattern):不同條件下創(chuàng)建不同實(shí)例
單例模式 (Singleton Pattern)**:保證一個(gè)類僅有一個(gè)實(shí)例
建造者模式 (Builder Pattern)**:將一個(gè)復(fù)雜的構(gòu)建過程與其具表示細(xì)節(jié)相分離,使得同樣的構(gòu)建過程可以創(chuàng)建不同的表示
原型模式 (Prototype Pattern)**:通過拷貝原型創(chuàng)建新的對(duì)象
結(jié)構(gòu)型模式
這些設(shè)計(jì)模式關(guān)注類和對(duì)象的組合戒财。
適配器模式 (Adapter Pattern)**:使得原本由于接口不兼容而不能一起工作的那些類可以一起工作
裝飾器模式 (Decorator Pattern)**:保持接口热监,增強(qiáng)性能:修飾類繼承被修飾對(duì)象的抽象父類,依賴被修飾對(duì)象的實(shí)例(被修飾對(duì)象依賴注入)饮寞,以實(shí)現(xiàn)接口擴(kuò)展
橋接模式 (Bridge Pattern)**:兩個(gè)維度獨(dú)立變化孝扛,依賴方式實(shí)現(xiàn)抽象與實(shí)現(xiàn)分離:需要一個(gè)作為橋接的接口/抽象類,多個(gè)角度的實(shí)現(xiàn)類依賴注入到抽象類幽崩,使它們?cè)诔橄髮咏⒁粋€(gè)關(guān)聯(lián)關(guān)系
外觀模式 (Facade Pattern)**:在客戶端和復(fù)雜系統(tǒng)之間再加一層苦始,這一次將調(diào)用順序、依賴關(guān)系等處理好慌申。即封裝底層實(shí)現(xiàn)陌选,隱藏系統(tǒng)的復(fù)雜性,并向客戶端提供了一個(gè)客戶端可以訪問系統(tǒng)的高層接口
代理模式 (Proxy Pattern)**:為其他對(duì)象提供一種代理以控制對(duì)這個(gè)對(duì)象的訪問:增加中間層(代理層)蹄溉,代理類與底層實(shí)現(xiàn)類實(shí)現(xiàn)共同接口咨油,并創(chuàng)建底層實(shí)現(xiàn)類對(duì)象(底層實(shí)現(xiàn)類對(duì)象依賴注入代理類),以便向外界提供功能接口
過濾器模式 (Filter柒爵、Criteria Pattern)**:使用不同的標(biāo)準(zhǔn)來過濾一組對(duì)象役电,通過邏輯運(yùn)算以解耦的方式把它們連接起來
組合模式 (Composite Pattern)**:用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性的統(tǒng)一接口
享元模式 (Flyweight Pattern)**:享元工廠類控制;HashMap實(shí)現(xiàn)緩沖池重用現(xiàn)有的同類對(duì)象棉胀,如果未找到匹配的對(duì)象法瑟,則創(chuàng)建新對(duì)象
行為型模式
這些設(shè)計(jì)模式特別關(guān)注對(duì)象之間的通信。
責(zé)任鏈模式(Chain of Responsibility Pattern)**:攔截的類都實(shí)現(xiàn)統(tǒng)一接口唁奢,每個(gè)接收者都包含對(duì)下一個(gè)接收者的引用瓢谢。將這些對(duì)象連接成一條鏈,并且沿著這條鏈傳遞請(qǐng)求驮瞧,直到有對(duì)象處理它為止。
觀察者模式(Observer Pattern)**:一對(duì)多的依賴關(guān)系枯芬,在觀察目標(biāo)類里有一個(gè) ArrayList 存放觀察者們论笔。當(dāng)觀察目標(biāo)對(duì)象的狀態(tài)發(fā)生改變,所有依賴于它的觀察者都將得到通知千所,使這些觀察者能夠自動(dòng)更新(即使用推送方式)
模板模式(Template Pattern)**:將這些通用算法抽象出來狂魔,在一個(gè)抽象類中公開定義了執(zhí)行它的方法的方式/模板。它的子類可以按需要重寫方法實(shí)現(xiàn)淫痰,但調(diào)用將以抽象類中定義的方式進(jìn)行
命令模式(Command Pattern)**:將"行為請(qǐng)求者"與"行為實(shí)現(xiàn)者"解耦:調(diào)用者依賴命令最楷,命令依賴接收者,調(diào)用者Invoker→命令Command→接收者Receiver
解釋器模式(Interpreter Pattern):給定一個(gè)語言,定義它的文法表示籽孙,并定義一個(gè)解釋器烈评,這個(gè)解釋器使用該標(biāo)識(shí)來解釋語言中的句子
迭代器模式(Iterator Pattern):集合中含有迭代器:分離了集合對(duì)象的遍歷行為,抽象出一個(gè)迭代器類來負(fù)責(zé)犯建,無須暴露該對(duì)象的內(nèi)部表示
中介者模式(Mediator Pattern)**:對(duì)象與對(duì)象之間存在大量的關(guān)聯(lián)關(guān)系讲冠,將對(duì)象之間的通信關(guān)聯(lián)關(guān)系封裝到一個(gè)中介類中單獨(dú)處理,從而使其耦合松散适瓦,可以獨(dú)立地改變它們之間的交互
策略模式(Strategy Pattern)**:策略對(duì)象依賴注入到context對(duì)象竿开,context對(duì)象根據(jù)它的策略改變而改變它的相關(guān)行為(可通過調(diào)用內(nèi)部的策略對(duì)象實(shí)現(xiàn)相應(yīng)的具體策略行為)
狀態(tài)模式(State Pattern)**:狀態(tài)對(duì)象依賴注入到context對(duì)象,context對(duì)象根據(jù)它的狀態(tài)改變而改變它的相關(guān)行為(可通過調(diào)用內(nèi)部的狀態(tài)對(duì)象實(shí)現(xiàn)相應(yīng)的具體行為)
備忘錄模式(Memento Pattern):通過一個(gè)備忘錄類專門存儲(chǔ)對(duì)象狀態(tài)玻熙》癫剩客戶通過備忘錄管理類管理備忘錄類。
空對(duì)象模式(Null Object Pattern):創(chuàng)建一個(gè)未對(duì)該類做任何實(shí)現(xiàn)的空對(duì)象類嗦随,該空對(duì)象類將無縫地使用在需要檢查空值的地方列荔。不要為了屏蔽null而使用空對(duì)象,應(yīng)保持用null称杨,遠(yuǎn)比用非null的值來替代“無值”要好肌毅。(慎用)