模板方法模式(Template Method Pattern)
在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。
简单点说,超类的模板方法中定义了一个算法的步骤,并允许子类为一个或多个步骤提供实现。这样模板方法就控制并保护了算法,算法中的步骤可以由超类实现,也可以由各个子类根据自己的需要实现(在超类中声明为abstract)。这样模板方法本身和步骤的具体实现之间就解耦了。
有几点需要注意:超类需要声明为abstract抽象类;模板方法必须是final来避免子类覆写而导致算法顺序的改变;超类已经实现的算法步骤必须是final以避免被子类覆写;超类中可以有什么都不做的方法(钩子),子类可以视情况来决定是否覆写该方法。
模板方法模式的思想很容易理解,但对于Java中钩子(hook)的灵活使用却不易掌握,钩子是被声明在抽象类中的方法,但只有空或默认的实现。钩子可以让子类有能力为其抽象类做一些决定(父类的某些逻辑可以依赖子类方法的结果)。
- 好莱坞原则(Hollywood Principle)
- 不要给我们打电话,我们会给你打电话(don‘t call us, we‘ll call you)
- 尽量避免向上调用和互相调用,高层会在适当时候调用低层
- 不要给我们打电话,我们会给你打电话(don‘t call us, we‘ll call you)