模板方法模式在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。
要点:
- “模板方法”定义了算法的步骤,把这些步骤的实现延迟到子类。
- 模板方法模式为我们提供了一种代码复用的重要技巧。
- 模板方法的抽象类可以定义具体的方法、抽象的方法和钩子。(钩子:是一种被声明在抽象类中的方法,但只有空的或者默认的实现。钩子的存在可以让子类有能力对算法的不同点进行挂钩。)
- 抽象方法由子类实现。
- 钩子是一种方法,它在抽象中不做事,或者只做默认的事情,子类可以选择要不要去实现它。
- 好莱坞原则告诉我们,将决策权放在高层模块中,以便决定如何以及何时调用低层模块。(好莱坞原则:别调用(打电话给)我们,我们会调用(打电话给)你。)
- 策略模式和模板方法模式都封装算法,一个用组合,一个用继承。
- 工厂方法是模板方法的一个特殊版本。
模板方法:子类决定如何实现算法中的某些步骤。(继承方式)
策略模式:封装可以互换的行为,然后使用委托来决定采用哪一个行为。(组合方式)