模板方法很早就知道这个名词,但是让我说,我也不确定这到底是做什么的,但是看到这个定义后的第一个想法就是我经常在用啊
定义一个操作中的算法的框架,而将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可定义该算法的某些特定步骤。
经常会遇到这样一个场景,父类分几个步骤,这几个步骤单独都是抽象的方法,然后在一个方法中使用这些步骤,步骤的实现是由子类来实现,步骤是一样的,但是其中一些抽象函数是不同的,通过在运行时加载不同的子类来动态的控制实现。
项目中使用:
1、生成事件的js代码,生成事件的js代码分为版本3和版本4,步骤都是一样的,但是其中一些步骤细节处理方法不同,就建立了一个抽象类,里面包含一些抽象方法,在版本3和版本4的实现类中分别对抽象方法进行实现。它是和工厂模式一起使用的,和上一篇文章一样用的是简单工作模式,我的想法是它是不是也可以使用单例模式,因为版本3和版本4的实现其实是不变的,不需要建立多个对象实例,由于设计到版本3的实现和版本4的实现,应该用map来实现单例。
2、项目中使用的ListViewFieldEditor,里面包含了下面提到的两种钩子方法
要注意的问题是:
1、需要子类实现的方法设置为protected,减少与外界的耦合
2、空实现的方法,我们称这种方法为”hook”。子类可以视情况来决定是否要覆盖它。
3、为了防止子类改变模板中的算法,可以将模板方法声明为final。
4、钩子是一种方法,它在抽象类中不做事,或只做默认的事,子类可以选择要不要实现它。
钩子方法分两种,一种是可以与一些具体方法挂钩来控制算法的步骤,还有一种是空实现,它与抽象方法的区别是子类可以不覆盖该方法,而抽象方法子类必须覆盖否则会报错的。