設(shè)計(jì)模式(Design pattern)是一套被反復(fù)使用诡延、多數(shù)人知曉的竭钝、經(jīng)過分類編目的、代碼設(shè)計(jì)經(jīng)驗(yàn)的總結(jié)燥滑。使用設(shè)計(jì)模式是為了可重用代碼渐北、讓代碼更容易被他人理解、保證代碼可靠性突倍。毫無疑問腔稀,設(shè)計(jì)模式于己于他人于系統(tǒng)都是多贏的,設(shè)計(jì)模式使代碼編制真正工程化羽历,設(shè)計(jì)模式是軟件工程的基石焊虏,如同大廈的一塊塊磚石一樣。項(xiàng)目中合理的運(yùn)用設(shè)計(jì)模式可以完美的解決很多問題秕磷,每種模式在現(xiàn)在中都有相應(yīng)的原理來與之對(duì)應(yīng)诵闭,每一個(gè)模式描述了一個(gè)在我們周圍不斷重復(fù)發(fā)生的問題,以及該問題的核心解決方案,這也是它能被廣泛應(yīng)用的原因疏尿。
1.設(shè)計(jì)模式的分類
創(chuàng)建型模式:
Singleton瘟芝,單例模式:保證一個(gè)類只有一個(gè)實(shí)例,并提供一個(gè)訪問它的全局訪問點(diǎn)褥琐。
Abstract Factory锌俱,抽象工廠:提供一個(gè)創(chuàng)建一系列相關(guān)或相互依賴對(duì)象的接口,而無須指定它們的具體類敌呈。
Factory Method贸宏,工廠方法:定義一個(gè)用于創(chuàng)建對(duì)象的接口,讓子類決定實(shí)例化哪一個(gè)類磕洪,F(xiàn)actory Method使一個(gè)類的實(shí)例化延遲到了子類吭练。
Builder,建造模式:將一個(gè)復(fù)雜對(duì)象的構(gòu)建與他的表示相分離析显,使得同樣的構(gòu)建過程可以創(chuàng)建不同的表示鲫咽。
Prototype,原型模式:用原型實(shí)例指定創(chuàng)建對(duì)象的種類谷异,并且通過拷貝這些原型來創(chuàng)建新的對(duì)象分尸。
行為型模式:
Iterator,迭代器模式:提供一個(gè)方法順序訪問一個(gè)聚合對(duì)象的各個(gè)元素晰绎,而又不需要暴露該對(duì)象的內(nèi)部表示寓落。
Observer括丁,觀察者模式:定義對(duì)象間一對(duì)多的依賴關(guān)系荞下,當(dāng)一個(gè)對(duì)象的狀態(tài)發(fā)生改變時(shí),所有依賴于它的對(duì)象都得到通知自動(dòng)更新史飞。
Template Method尖昏,模板方法:定義一個(gè)操作中的算法的骨架,而將一些步驟延遲到子類中构资,TemplateMethod使得子類可以不改變一個(gè)算法的結(jié)構(gòu)即可以重定義該算法得某些特定步驟抽诉。
Command,命令模式:將一個(gè)請(qǐng)求封裝為一個(gè)對(duì)象吐绵,從而使你可以用不同的請(qǐng)求對(duì)客戶進(jìn)行參數(shù)化迹淌,對(duì)請(qǐng)求排隊(duì)和記錄請(qǐng)求日志,以及支持可撤銷的操作己单。
State唉窃,狀態(tài)模式:允許對(duì)象在其內(nèi)部狀態(tài)改變時(shí)改變他的行為。對(duì)象看起來似乎改變了他的類纹笼。
Strategy纹份,策略模式:定義一系列的算法,把他們一個(gè)個(gè)封裝起來,并使他們可以互相替換蔓涧,本模式使得算法可以獨(dú)立于使用它們的客戶件已。
China of Responsibility,職責(zé)鏈模式:使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求元暴,從而避免請(qǐng)求的送發(fā)者和接收者之間的耦合關(guān)系
Mediator篷扩,中介者模式:用一個(gè)中介對(duì)象封裝一些列的對(duì)象交互。
Visitor茉盏,訪問者模式:表示一個(gè)作用于某對(duì)象結(jié)構(gòu)中的各元素的操作瞻惋,它使你可以在不改變各元素類的前提下定義作用于這個(gè)元素的新操作。
Interpreter援岩,解釋器模式:給定一個(gè)語言歼狼,定義他的文法的一個(gè)表示,并定義一個(gè)解釋器享怀,這個(gè)解釋器使用該表示來解釋語言中的句子羽峰。
Memento,備忘錄模式:在不破壞對(duì)象的前提下添瓷,捕獲一個(gè)對(duì)象的內(nèi)部狀態(tài)梅屉,并在該對(duì)象之外保存這個(gè)狀態(tài)。
結(jié)構(gòu)型模式:
Composite鳞贷,組合模式:將對(duì)象組合成樹形結(jié)構(gòu)以表示部分整體的關(guān)系坯汤,Composite使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。
Facade搀愧,外觀模式:為子系統(tǒng)中的一組接口提供一致的界面惰聂,fa?ade提供了一高層接口,這個(gè)接口使得子系統(tǒng)更容易使用咱筛。
Proxy搓幌,代理模式:為其他對(duì)象提供一種代理以控制對(duì)這個(gè)對(duì)象的訪問
Adapter,適配器模式:將一類的接口轉(zhuǎn)換成客戶希望的另外一個(gè)接口,Adapter模式使得原本由于接口不兼容而不能一起工作那些類可以一起工作迅箩。
Decrator溉愁,裝飾模式:動(dòng)態(tài)地給一個(gè)對(duì)象增加一些額外的職責(zé),就增加的功能來說饲趋,Decorator模式相比生成子類更加靈活拐揭。
Bridge,橋模式:將抽象部分與它的實(shí)現(xiàn)部分相分離奕塑,使他們可以獨(dú)立的變化堂污。
Flyweight,享元模式
2.模板方法Template Method
概述
模板方法模式是類的行為模式爵川。準(zhǔn)備一個(gè)抽象類敷鸦,將部分邏輯以具體方法以及具體構(gòu)造函數(shù)的形式實(shí)現(xiàn),然后聲明一些抽象方法來迫使子類實(shí)現(xiàn)剩余的邏輯。不同的子類可以以不同的方式實(shí)現(xiàn)這些抽象方法扒披,從而對(duì)剩余的邏輯有不同的實(shí)現(xiàn)值依。這就是模板方法模式的用意。
比如定義一個(gè)操作中的算法的骨架碟案,將步驟延遲到子類中愿险。模板方法使得子類能夠不去改變一個(gè)算法的結(jié)構(gòu)即可重定義算法的某些特定步驟。
模式中的角色
抽象類(AbstractClass):實(shí)現(xiàn)了模板方法价说,定義了算法的骨架辆亏。
具體類(ConcreteClass):實(shí)現(xiàn)抽象類中的抽象方法,已完成完整的算法鳖目。
//抽象模板
public abstract class AbstractClass{
? ? ? ? protected abstract void doAnyting();
? ? ? ? protected abstract void doSomething();
? ? ? ? public void templateMethod(){
? ? ? ? ? ? ? doAnyting();
? ? ? ? ? ? ?doSomething();
? ? ? ? }
}
public class ConcreteClass1 extends AbstractClass{
? ? ? ? @Override
? ? ? ? ?protected void doAnyting(){
? ? ? ? ? ? ? ? System.out.println("do class1 anything");
? ? ? ? ? }
? ? ? ? ?@Override
? ? ? ? ?protected void doSomething(){
? ? ? ? ? ? ? ? System.out.println("do class1 something");
? ? ? ? ?}
}
public class ConcreteClass2 extends AbstractClass{
? ? ? ?@Override
? ? ? ? protected void doAnyting(){
? ? ? ? ? ? ? ? System.out.println("do class2 anything");
? ? ? ? ?}
? ? ? ? @Override
? ? ? ? protected void doSomething(){
? ? ? ? ? ? ? System.out.println("do class2 something");
? ? ? ? ?}
}
public class Client{
? ? ? ? ?public static void main(final String[] args){
? ? ? ? ? ? ? ? ?final AbstractClass c1 = new ConcreteClass1();
? ? ? ? ? ? ? ? ?final AbstractClass c2 = new ConcreteClass2();
? ? ? ? ? ? ? ? c1.templateMethod();
? ? ? ? ? ? ? ? c2.templateMethod();
? ? ? ? ? ? }
}