定義乙個操作中演算法的框架,而將一些步驟延遲到子類中。模板方法模式使得子類可以不改變乙個演算法的結構即可重定義該演算法的某些特定步驟。
解決的問題
提高**復用性
將相同部分的**放在抽象的父類中,而將不同的**放入不同的子類中 實現了反向控制。通過乙個父類呼叫其子類的操作,通過對子類的具體實現擴充套件不同的行為,實現了反向控制 & 符合「開閉原則」
abstractclass(抽象類):在抽象類中定義了一系列基本操作,這些基本操作可以是具體的,也可以是抽象的,每乙個基本操作對應演算法的乙個步驟,在其子類中可以重定義或實現這些步驟。同時,在抽象類中實現了乙個模板方法(template method),用於定義乙個演算法的框架,模板方法不僅可以呼叫在抽象類中實現的基本方法,也可以呼叫在抽象類的子類中實現的基本方法,還可以呼叫其他物件中的方法。
concreteclass(具體子類):它是抽象類的子類,用於實現在父類中宣告的抽象基本操作以完成子類特定演算法的步驟,也可以覆蓋在父類中已經實現的具體基本操作。
做菜,做菜說簡單也簡單,說難也難。但是大體分為幾步:洗鍋,洗菜,切菜,翻炒,出鍋。是固定的
//abstractclass
class
meal
void
washpot()
//這一步是一定的,就不需要子類去寫了。
virtual
void
washvegetable()
=0;//洗菜
virtual
void
cutvegetable()
=0;//切菜
virtual
void
inpot()
=0;//下鍋
virtual
void
outpot()
=0;//出鍋};
//concreteclass
class
shreddedporkwithgarlicsauce
:public meal
void
cutvegetable()
void
inpot()
void
outpot()
};class
mapobeancurd
:public meal
void
cutvegetable()
void
inpot()
//我還真不知道怎麼做
void
outpot()
};intmain()
{ shreddedporkwithgarlicsauce spwithgs;
spwithgs.
cook()
; mapobeancurd mapo;
mapo.
cook()
;getchar()
;return
0;
結果
優點:
在父類中形式化地定義乙個演算法,而由它的子類來實現細節的處理,在子類實現詳細的處理演算法時並不會改變演算法中步驟的執行次序。
模板方法模式是一種**復用技術,它在類庫設計中尤為重要,它提取了類庫中的公共行為,將公共行為放在父類中,而通過其子類來實現不同的行為,它鼓勵我們恰當使用繼承來實現**復用。
可實現一種反向控制結構,通過子類覆蓋父類的鉤子方法來決定某一特定步驟是否需要執行。
在模板方法模式中可以通過子類來覆蓋父類的基本方法,不同的子類可以提供基本方法的不同實現,更換和增加新的子類很方便,符合單一職責原則和開閉原則。
缺點:
需要為每乙個基本方法的不同實現提供乙個子類,如果父類中可變的基本方法太多,將會導致類的個數增加,系統更加龐大,設計也更加抽象。
具有統一的操作步驟或操作過程; 具有不同的操作細節; 存在多個具有同樣操作步驟的應用場景,但某些具體的操作細節卻各不相同;
模板方法模式
有這樣乙個場景 乙個演算法或流程,它的步驟以及步驟之間的順序是固定的,但具體的某一步可能有不同的實現。對於這麼乙個場景,可以建立多個類,各個類實現不同的實現,但是這樣的缺點是 易錯 難改,易錯 應為步驟和順序是固定的,而且在每個類中都要寫一遍,程式設計師怎有心情不好的時候,就有可能把其中某一步給寫錯...
模板方法模式
模板方法模式 定義乙個演算法框架,將裡面的操作步驟推遲到子類中去執行,這樣使得子類不用改變框架,只需改變某些操作步驟方法 ifndef test h define test h include include using namespace std class test virtual test v...
模板方法模式
模板方法模式 在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以在不改變演算法結構的情況下,重新定義演算法的某些步驟。還可以使用鉤子對可選部分進行判斷。include include using namespace std class caffeinebeverage ...