什么是模板模式
定義一個(gè)操作中的算法框架,而將一些步驟延遲到子類中端三,使得子類可以不改變一個(gè)算法的結(jié)構(gòu)即可重定義該算法的特定步驟。
標(biāo)準(zhǔn)的定義還是稍微有點(diǎn)苦澀難懂的, 大白話就是只要按照我的套路來耸弄,你就不會錯(cuò)。
生活中盡是套路
記得高中的時(shí)候卓缰,數(shù)學(xué)老師叫我們怎么求解一個(gè)數(shù)學(xué)問題:
第1步:認(rèn)真審題计呈,找出里面的已知變量和未知變量。
第2步:根據(jù)變量之間的關(guān)系創(chuàng)建對應(yīng)的關(guān)系表達(dá)式征唬。
第3步:通過關(guān)系式和常用的定律和公式求解未知變量捌显。
那么這個(gè)就是咱們數(shù)學(xué)老師給咱們的套路,只要按照這個(gè)套路來总寒,求解是沒有問題的扶歪。
看看模板模式的骨架
其中的run()方法,已經(jīng)在父類里面實(shí)現(xiàn)好了摄闸,run()方法里面調(diào)用的是需要子類進(jìn)行實(shí)現(xiàn)的方法善镰,如上面的doAnything()和doOthering()方法,子類只要按照父類的套路年枕,實(shí)現(xiàn)剩下的方法炫欺,然后調(diào)用父類的run()方法,就ok了画切。
模板模式的缺點(diǎn)
按照程序的設(shè)計(jì)習(xí)慣竣稽,一般父類都是負(fù)責(zé)抽象,子類才是真正負(fù)責(zé)實(shí)現(xiàn),但是模板模式毫别,父類里面也是有具體的實(shí)現(xiàn)的方法娃弓,并且子類的執(zhí)行結(jié)果影響父類的執(zhí)行結(jié)果,在代碼閱讀上面岛宦,可能會有些不適
注意事項(xiàng)
父類中有的具體實(shí)現(xiàn)台丛,不需要子類進(jìn)行重寫的話,已經(jīng)要使用final進(jìn)行修飾砾肺,以此來禁止子類的不規(guī)范重寫挽霉,導(dǎo)致最終的執(zhí)行結(jié)果發(fā)生異常。