在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模版方法使得子類可以在不改變演算法結構的情況下,重新定義演算法中某些步驟。模版方法模式為我們提供了一種**復用的重要技巧。抽象方法由子類實現。
//建立抽象模板
public abstract class abstract class
//定義結構裡哪些方法是所有過程都是一樣的可復用的,哪些是需要子類進行實現的
//第一步:倒油是一樣的,所以直接實現
void pouroil()
//第二步:熱油是一樣的,所以直接實現
void heatoil()
//第三步:倒蔬菜是不一樣的(乙個下包菜,乙個是下菜心)
//所以宣告為抽象方法,具體由子類實現
abstract void pourvegetable();
//第四步:倒調味料是不一樣的(乙個下辣椒,乙個是下蒜蓉)
//所以宣告為抽象方法,具體由子類實現
abstract void poursauce();
//第五步:翻炒是一樣的,所以直接實現
void fry();
}//建立具體模板,進行可變部分的實現
//炒手撕包菜的類
public class concreteclass_baocai extend abstract class
@override
public void poursauce()
}//炒蒜蓉菜心的類
public class concreteclass_caixin extend abstract class
@override
public void poursauce()
}//應用場景
public class template method
}原文:
提高**復用性 ,將相同部分的**放在抽象的父類中;提高了拓展性 ,將不同的**放入不同的子類中,通過對子類的擴充套件增加新的行為;實現了反向控制 ,通過乙個父類呼叫其子類的操作,通過對子類的擴充套件增加新的行為,實現了反向控制 & 符合「開閉原則」
引入了抽象類,每乙個不同的實現都需要乙個子類來實現,導致類的個數增加,從而增加了系統實現的複雜度。
模板方法模式
有這樣乙個場景 乙個演算法或流程,它的步驟以及步驟之間的順序是固定的,但具體的某一步可能有不同的實現。對於這麼乙個場景,可以建立多個類,各個類實現不同的實現,但是這樣的缺點是 易錯 難改,易錯 應為步驟和順序是固定的,而且在每個類中都要寫一遍,程式設計師怎有心情不好的時候,就有可能把其中某一步給寫錯...
模板方法模式
模板方法模式 定義乙個演算法框架,將裡面的操作步驟推遲到子類中去執行,這樣使得子類不用改變框架,只需改變某些操作步驟方法 ifndef test h define test h include include using namespace std class test virtual test v...
模板方法模式
模板方法模式 在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以在不改變演算法結構的情況下,重新定義演算法的某些步驟。還可以使用鉤子對可選部分進行判斷。include include using namespace std class caffeinebeverage ...