1. 使用了繼承,並肯定了這個繼承的意義,就應該要成為子類的模板,所有重複的**都應該要上公升到父類去,而不是讓每個子類都去重複。
2. 當我們要完成在某一細節層次一致的乙個過程或一系列步驟,但其個別步驟在更詳細的層次上的實現可能不同時,我們通常考慮用模板來處理。
3.定義乙個操作中的演算法的骨架,而將其中的一些步驟延遲到子類中。模板方法使得子類可以不改變乙個演算法的結構即可重定義該演算法的某些特定的步驟。
4. 在抽象父類(抽象模板)中定義虛方法,在子類中實現這個虛方法,通過對抽象父類例項化不同的子類從而呼叫不同的子類實現方法是模板方法的實現方式,在模板方法中注重的就是模板二字,盡可能把不變行為放在父類模板方法中,也就是包含子類實現父類虛方法的方法。
5. 抽象模板(抽象類),定義並實現了乙個模板方法(就是包含自身定義的抽象方法的public方法),這個模板方法一般是乙個具體的方法,他給出了乙個頂級邏輯的骨架,而邏輯的組成步驟在相應的抽象操作中,推遲到子類實現。
6.子類實現父類所定義的乙個或多個抽象方法,每個抽象模板都可以有任意多個子類與之對應,而每乙個子類都可以給出這些抽象方法(抽象模板的組成步驟)不同的實現。
7.模板方法模式是通過把不變行為搬移到超類,去除子類中的重複**來體現他的優勢的,提供乙個很好的**復用平台。
8. 當過程從高層次上看是相同的,但有些步驟的實現可能不同,這時候,我們通常就應該要考慮用模板方法模式了
9. 當不變和可變的行為在方法的子類實現中混合在一起的時候,不變的行為就會在子類中重複出現。我們通過模板方法模式把這些行為搬移到單一的地方(抽象父類的模板方法),這樣就幫助了子類擺脫重複的不變行為的糾纏。
10.模板方法模式十分常用也比較容易理解,通常都會利用其提取公共行為到抽象類中
using system;using system.collections.generic;
using system.text;
namespace 模板方法模式
}abstract class
abstractclass
}class
concreteclassa : abstractclass
public override void primitiveoperation2()
}class
concreteclassb : abstractclass
public override void primitiveoperation2()}}
模板方法模式
有這樣乙個場景 乙個演算法或流程,它的步驟以及步驟之間的順序是固定的,但具體的某一步可能有不同的實現。對於這麼乙個場景,可以建立多個類,各個類實現不同的實現,但是這樣的缺點是 易錯 難改,易錯 應為步驟和順序是固定的,而且在每個類中都要寫一遍,程式設計師怎有心情不好的時候,就有可能把其中某一步給寫錯...
模板方法模式
模板方法模式 定義乙個演算法框架,將裡面的操作步驟推遲到子類中去執行,這樣使得子類不用改變框架,只需改變某些操作步驟方法 ifndef test h define test h include include using namespace std class test virtual test v...
模板方法模式
模板方法模式 在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以在不改變演算法結構的情況下,重新定義演算法的某些步驟。還可以使用鉤子對可選部分進行判斷。include include using namespace std class caffeinebeverage ...