模板模式

模板设计模式

定义:在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中去。模板方法可以使子类在不改变算法结构的前提下,重新定义算法中的某些定义。

比喻说明:模板模式就像是做煎饼果子,每做一个煎饼果子的步骤都一样:烙饼—>加调料(包括鸡蛋、火腿等)—>卷饼—>打包,除了加的调料不一样之外其余都一样,这时我们就可以定义一个煎饼果子类,制作步骤都封装起来,唯独将加调料的方法交给子类实现。

案例代码说明

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()方法来实现自定义的排序。

你可能感兴趣的:(模板模式)