模板设计模式
定义:在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中去。模板方法可以使子类在不改变算法结构的前提下,重新定义算法中的某些定义。
比喻说明:模板模式就像是做煎饼果子,每做一个煎饼果子的步骤都一样:烙饼—>加调料(包括鸡蛋、火腿等)—>卷饼—>打包,除了加的调料不一样之外其余都一样,这时我们就可以定义一个煎饼果子类,制作步骤都封装起来,唯独将加调料的方法交给子类实现。
案例代码说明
1,定义抽象父类——>煎饼果子类
public abstract class TortillaFlat {
//制作煎饼果子方法
public void makeTortillaFlat(){
// 将步骤封装
makeCake();
addSeasoning();
rollupCake();
baleCake();
}
private void makeCake(){
Log.e("模板模式","烙饼");
}
private void rollupCake(){
Log.e("模板模式","卷饼");
}
private void baleCake(){
Log.e("模板模式","打包");
}
protected abstract void addSeasoning();
}
2,定义子类——>加鸡蛋煎饼果类(这里也可以定义加培根或者烤肠的)
public class EggTortillaFlat extends TortillaFlat {
@Override
protected void addSeasoning() {
Log.e("模板模式","加入鸡蛋");
}
}
3,创建加鸡蛋对象实例执行制作煎饼果子方法
TortillaFlat eggTortillaFlat = new EggTortillaFlat();
eggTortillaFlat.makeTortillaFlat();
4,执行结果
总结:模板其实就是一个方法类似于上面例子里的制作煎饼果子方法makeTortillaFlat(),它将算法定义成一组步骤,其中任何步骤都是可以被抽象然后由子类实现的,这样可以保证算法结构的稳定同时由子类提供部分实现。在java中的集合排序就是使用的模板模式,通过实现compareTo()方法来实现自定义的排序。