模板模式

模板设计模式

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

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

案例代码说明

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在 JavaScript 开发中用到继承的场景其实并不是很多,很多时候我们都喜欢用 mix-in 的方式给对象扩展...
    风铭阅读 3,012评论 0 0
  • 1.模板方法模式概念 模板模式(Template Pattern)中,一个抽象类公开定义了执行它的方法的方式/模板...
    lgy_gg阅读 4,050评论 0 2
  • 概念与定义 在模板模式(Template Pattern)中,一个抽象类公开定义了执行它的方法的方式/模板。它的子...
    maxwellyue阅读 2,900评论 0 0
  • 1.认识模板方法 模板方法定义了一个算法的步骤,并允许子类为一个或多个步骤提供实现。使得子类可以在不改变算法结构的...
    Mcyboy007阅读 1,306评论 0 0
  • 定义 模板方法模式定义了一个算法的步骤,并允许子类别为一个或多个步骤提供其实践方式。让子类别在不改变算法架构的情况...
    风水里游阅读 2,515评论 0 2