模板方法模式:定義乙個操作演算法中框架,而將一些步驟延遲到子類中.模板方法模式使得子類可以不改變乙個演算法的結構既可定義該演算法的某些特定步驟.
1)abstractclass(抽象類):在抽象類中定義了一系列基本操作(primitiveoperations).這些基本操作可以是具體的,也可以是抽象的,每乙個基本操作對應演算法的乙個步驟在其子類中可以重定義或實現這些步驟.同時,在抽象類中實現了乙個模板方法,用於定義個演算法的框架,模板方法不僅可以呼叫在抽象類中實現的基本方法,也可以呼叫在抽象類的子類中實現的基本方法,還可以呼叫其他物件中的方法.
2)concreteclass(具體子類):它是抽象類的子類,用於實現在父類中宣告的抽象基本操作以完成子類特定演算法的步驟,也可以覆蓋在父類中已經實現的具體基本操作.
public
abstract
class
template
public
void
primitiveoperation1()
public
abstract
void
primitiveoperation2()
;public
abstract
void
primitiveoperation3()
;}
public
class
concreteclassa extends template
@override
public
void
primitiveoperation3()
}
public
class
concreteclassb extends template
@override
public
void
primitiveoperation3()
}
public
class
client
}
主要優點:
1)在父類中形式化的定義乙個演算法,而由它的子類來實現細節的處理,在子類實現詳細的處理演算法時並不會改變演算法中步驟的執行順序;
2)模板方法模式是一種**復用技術,它在類庫設計中尤為重要,它提取了類庫中的公共行為,將公共行為放在父類中,而通過其子類來實現不同的行為,它鼓勵我們恰當適用繼承來實現**復用.
3)可實現一種反向控制結構,通過子類覆蓋父類的鉤子方法來決定某一特定步驟是否需要執行
4)在模板方法模式中可以通過子類來覆蓋父類的基本方法,不同的子類可以提供基本方法的不同實現,更換和增加新的子類很方便,符合單一職責原則和開閉原則
主要缺點:
需要為每乙個基本方法的不同實現提供乙個子類,如果父類中可變的基本方法太多,將會導致類的個數增加,系統更加龐大,設計也更加抽象,此時,可結合橋接模式來進行設計.
適用場景:
1)對一些複雜的演算法進行分割,將其演算法中固定不變的部分設計為模板方法和父類具體方法,而一些可以改變的細節由其子類來實現.即:一次性實現乙個演算法的不變部分,並將可變的部分留給子類實現.
2)各子類中公共的行為應被提取出來並集中到乙個公共父類中以避免**重複.
3)需要通過子類來決定父類演算法中某個步驟是否執行,實現子類對父類的反向控制.
模板方法模式
有這樣乙個場景 乙個演算法或流程,它的步驟以及步驟之間的順序是固定的,但具體的某一步可能有不同的實現。對於這麼乙個場景,可以建立多個類,各個類實現不同的實現,但是這樣的缺點是 易錯 難改,易錯 應為步驟和順序是固定的,而且在每個類中都要寫一遍,程式設計師怎有心情不好的時候,就有可能把其中某一步給寫錯...
模板方法模式
模板方法模式 定義乙個演算法框架,將裡面的操作步驟推遲到子類中去執行,這樣使得子類不用改變框架,只需改變某些操作步驟方法 ifndef test h define test h include include using namespace std class test virtual test v...
模板方法模式
模板方法模式 在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以在不改變演算法結構的情況下,重新定義演算法的某些步驟。還可以使用鉤子對可選部分進行判斷。include include using namespace std class caffeinebeverage ...