思考模板模式
模板模式其实就是抽离共用方法到抽象类中,然后再规定其具体实现步骤
1.模板模式的本质
模板方法模式的本质:固定算法骨架。
模板模式的本质是定义一个算法的骨架,将一些步骤的实现延迟到子类中。模板模式通过定义一个抽象类或接口作为算法的模板,其中包含了一个或多个具体的方法,这些方法实现了算法的骨架,但其中的一些步骤的具体实现是由子类来完成的。
2.何时选用模板模式
建议在以下情况中选用模板方法模式。
-
当存在一组具有共同流程、但其中某些步骤的实现方式不同的算法时,可以使用模板模式。将这些共同的流程定义在模板中,具体的步骤由子类来实现。
-
当需要在不同的上下文中应用相同的算法骨架,但其中某些步骤的具体实现可能有所不同时,可以使用模板模式。通过定义一个通用的算法模板,在不同的上下文中继承并实现具体的步骤,可以实现算法的复用和定制。
-
当希望通过控制算法的流程来实现不同的行为变体时,可以使用模板模式。通过在模板中定义具体的步骤和钩子方法,可以灵活地控制算法的执行流程,从而实现不同的行为。
3.优缺点
优点
-
通过将具体步骤的实现延迟到子类中,实现了算法的复用和定制。不同的子类可以根据自己的需求来实现特定的步骤,而不影响算法的整体结构。
-
可以在不修改算法的整体结构的情况下,对某些步骤进行定制或扩展。通过在抽象模板类中定义钩子方法,子类可以选择性地覆盖这些方法,从而实现定制化的行为。
模板方法模式的缺点是算法骨架不容易升级。
- 模板方法模式最基本的功能就是通过模板的制定,把算法骨架完全固定下来。事实上模板和子类是非常耦合的,如果要对模板中的算法骨架进行变更,可能就会要求所有相关的子类进行相应的变化。所以抽取算法骨架的时候要特别小心,尽量确保是不会变化的部分才放到模板中。
4.模板方法的结构
-
抽象类或接口(Abstract Class or Interface):定义了算法的模板,它包含了一个或多个抽象方法和具体方法。抽象方法用于延迟到子类中实现,而具体方法提供算法的骨架,它们可以是具体实现,也可以是默认实现。
-
具体类(Concrete Class):实现了抽象类或接口中的抽象方法,完成算法中特定步骤的具体实现。
原语操作:即是抽象的操作,必须由子类提供实现
钩子操作:即是在模板中定义,并提供默认实现的操作,子类可以选择性重写
5.实现
定义一个oppo手机模板类,所有机型都使用的是oppo电池,但是使用的芯片不同,所以电池方法在模板类实现,芯片方法各个机型实现自己的。
1.模板及其实现类,模板方法设置为 final,防止被恶意重写
/**
* @description:手机模板类
*/
public abstract class Phone {
/**
* 钩子操作
* 安装电池
*/
void initBattery(){
System.out.println("安装oppo电池");
}
/**
* 原语操作
* 安装处理器
*/
abstract void initProcessor();
/**
* 初始化手机
*/
public final void init(){
initBattery();
initProcessor();
}
}
/**
* @description:OppoReno9 机型手机
*/
public class OppoReno9 extends Phone{
@Override
void initProcessor() {
System.out.println("使用高通骁龙778G处理器");
}
}
/**
* @description:OppoReno9Pro 机型手机
*/
public class OppoReno9Pro extends Phone {
@Override
void initProcessor() {
System.out.println("使用天玑 8100-MAX处理器");
}
}
2.测试类
/**
* @description:测试类
*/
public class Client {
public static void main(String[] args) {
Phone oppoReno9 = new OppoReno9();
oppoReno9.init();
Phone OppoReno9Pro = new OppoReno9Pro();
oppoReno9.init();
}
}
3.结果
安装oppo电池
使用高通骁龙778G处理器
安装oppo电池
使用高通骁龙778G处理器