什么是模板模式
定義一個操作中的算法框架,而將一些步驟延遲到子類中,使得子類可以不改變一個算法的結(jié)構(gòu)即可重定義該算法的特定步驟。
標(biāo)準(zhǔn)的定義還是稍微有點苦澀難懂的, 大白話就是只要按照我的套路來,你就不會錯。
生活中盡是套路
記得高中的時候,數(shù)學(xué)老師叫我們怎么求解一個數(shù)學(xué)問題:
第1步:認真審題,找出里面的已知變量和未知變量。
第2步:根據(jù)變量之間的關(guān)系創(chuàng)建對應(yīng)的關(guān)系表達式。
第3步:通過關(guān)系式和常用的定律和公式求解未知變量。
那么這個就是咱們數(shù)學(xué)老師給咱們的套路,只要按照這個套路來,求解是沒有問題的。
看看模板模式的骨架

火狐截圖_2017-09-26T15-24-51.161Z.png
其中的run()方法,已經(jīng)在父類里面實現(xiàn)好了,run()方法里面調(diào)用的是需要子類進行實現(xiàn)的方法,如上面的doAnything()和doOthering()方法,子類只要按照父類的套路,實現(xiàn)剩下的方法,然后調(diào)用父類的run()方法,就ok了。
模板模式的缺點
按照程序的設(shè)計習(xí)慣,一般父類都是負責(zé)抽象,子類才是真正負責(zé)實現(xiàn),但是模板模式,父類里面也是有具體的實現(xiàn)的方法,并且子類的執(zhí)行結(jié)果影響父類的執(zhí)行結(jié)果,在代碼閱讀上面,可能會有些不適
注意事項
父類中有的具體實現(xiàn),不需要子類進行重寫的話,已經(jīng)要使用final進行修飾,以此來禁止子類的不規(guī)范重寫,導(dǎo)致最終的執(zhí)行結(jié)果發(fā)生異常。