引出模板模式:
考試試卷問題,提煉後的**:
package這裡就用到了模板方法模式。com.disign.templetemethod;
import
org.junit.test;
/*** created by zhen on 2017-05-17. */
public
class
test*****
public
test*****(){}
public
void
testquestiona()
public
void
testquestionb()
public
void
testquestionc()
public
string answera()
public
string answerb()
public
string answerc()
public
void
show()
@test
public
void
testquestion()
}class test*****a extends
test*****
@override
public
string answera()
@override
public
string answerb()
@override
public
string answerc()
}class test*****b extends
test*****
@override
public
string answera()
@override
public
string answerb()
@override
public
string answerc()
}
模板方法模式:
定義乙個操作中演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類不改變乙個演算法的結構即可重定義該演算法某些特定步驟
abstractclass是抽象,其實也就是一抽象模板,定義並實現了乙個模板方法。這個模板方法一般是乙個具體方法,它給出了乙個頂級邏輯的骨架,而邏輯的組成步驟在相應的抽象操作中,推遲到子類實現。
conreteclass,實現父類所定義的乙個或者多個抽象方法。每乙個abstractclass都可以有人以有任意多個conreteclass與之對應,而每乙個conreteclass都可以給出這些抽象方法(也就是頂級邏輯的組成步驟)的不同實現,從而使得頂級邏輯的實現各不相同。
模板方法模式的特點:
模板方法模式是把不變行為搬移到超類,去除子類中的重複**來體現它的優勢
模板方法模式提供了乙個很好的**復用平台
當不變的和可變的行為在方法的子類實現中混合在一起的時候,不變的行為就會在子類中重複出現,我們使用模板方法模式,幫助子類擺脫重複的不變行為的糾纏。
模板方法模式
有這樣乙個場景 乙個演算法或流程,它的步驟以及步驟之間的順序是固定的,但具體的某一步可能有不同的實現。對於這麼乙個場景,可以建立多個類,各個類實現不同的實現,但是這樣的缺點是 易錯 難改,易錯 應為步驟和順序是固定的,而且在每個類中都要寫一遍,程式設計師怎有心情不好的時候,就有可能把其中某一步給寫錯...
模板方法模式
模板方法模式 定義乙個演算法框架,將裡面的操作步驟推遲到子類中去執行,這樣使得子類不用改變框架,只需改變某些操作步驟方法 ifndef test h define test h include include using namespace std class test virtual test v...
模板方法模式
模板方法模式 在乙個方法中定義乙個演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以在不改變演算法結構的情況下,重新定義演算法的某些步驟。還可以使用鉤子對可選部分進行判斷。include include using namespace std class caffeinebeverage ...