这是一个通俗易懂的模式,在笔者学习代码重构的时候经常会用类似的方式提炼代码。
模板方法:定义一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变算法的结构即能重定义算法的某些步骤。
原书UML如下:
原书demo如下:
TestPaper类主要内容如下:
子类如下:
调用类如下:
原书demo是c++,不过和java很相似,语义可以理解。
这里根据案例解释下模板方法的定义:
算法骨架,即TestPaper类内容,将一些步骤延迟到子类中,即TestPaper类的Answer()方法根据得到的值,使testQuestion()方法执行不同的逻辑,得到不同的结果。达到定义的“子类可以不改变算法的结构即能重定义算法的某些步骤”。
模板方法是通过不变的行为移动到父类,去除子类的重复代码来体现自己的优势,同时提供了很好的代码复用的平台。
本文介绍了模板方法设计模式的核心概念及其实现方式。通过具体案例分析了如何利用模板方法实现算法骨架,并允许子类在不改变整体结构的情况下重定义部分步骤。
178

被折叠的 条评论
为什么被折叠?



