1. 模板设计模式在书中定义:
    2. 定义一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变算法的结构即可
    3. 重定义该算法的某些特定步骤。
    4. 通俗点的理解就是 :完成一件事情,有固定的数个步骤,但是每个步骤根据对象的不同,而实现细节不同;
    5. 就可以在父类中定义一个完成该事情的总方法,按照完成事件需要的步骤去调用其每个步骤的实现方法。
    6. 每个步骤的具体实现,由子类完成。

    比如我们做菜可以分为三个步骤 (1)备料 (2)具体做菜 (3)盛菜端给客人享用,这三部就是算法的骨架 ;然而做不同菜需要的料,做的方法,以及如何盛装给客人享用都是不同的这个就是不同的实现细节。
    先来写一个抽象的做菜父类:

    1. public abstract class DodishTemplate {
    2. /**
    3. * 具体的整个过程
    4. */
    5. protected void dodish(){
    6. this.preparation();
    7. this.doing();
    8. this.carriedDishes();
    9. }
    10. /**
    11. * 备料
    12. */
    13. public abstract void preparation();
    14. /**
    15. * 做菜
    16. */
    17. public abstract void doing();
    18. /**
    19. * 上菜
    20. */
    21. public abstract void carriedDishes ();
    22. }

    下来做两个番茄炒蛋(EggsWithTomato)和红烧肉(Bouilli)实现父类中的抽象方法

    1. /**
    2. * 西红柿炒蛋
    3. * @author aries
    4. */
    5. public class EggsWithTomato extends DodishTemplate{
    6. @Override
    7. public void preparation() {
    8. System.out.println("洗并切西红柿,打鸡蛋。");
    9. }
    10. @Override
    11. public void doing() {
    12. System.out.println("鸡蛋倒入锅里,然后倒入西红柿一起炒。");
    13. }
    14. @Override
    15. public void carriedDishes() {
    16. System.out.println("将炒好的西红寺鸡蛋装入碟子里,端给客人吃。");
    17. }
    18. }
    1. /**
    2. * 红烧肉
    3. * @author aries
    4. *
    5. */
    6. public class Bouilli extends DodishTemplate{
    7. @Override
    8. public void preparation() {
    9. System.out.println("切猪肉和土豆。");
    10. }
    11. @Override
    12. public void doing() {
    13. System.out.println("将切好的猪肉倒入锅中炒一会然后倒入土豆连炒带炖。");
    14. }
    15. @Override
    16. public void carriedDishes() {
    17. System.out.println("将做好的红烧肉盛进碗里端给客人吃。");
    18. }
    19. }

    在测试类中我们来做菜

    1. public class App {
    2. public static void main(String[] args) {
    3. DodishTemplate eggsWithTomato = new EggsWithTomato();
    4. eggsWithTomato.dodish();
    5. System.out.println("-----------------------------");
    6. DodishTemplate bouilli = new Bouilli();
    7. bouilli.dodish();
    8. }
    9. }

    总结

    1. 模板模式的优点
    2. 1)具体细节步骤实现定义在子类中,子类定义详细处理算法是不会改变算法整体结构。
    3. 2)代码复用的基本技术,在数据库设计中尤为重要。
    4. 3)存在一种反向的控制结构,通过一个父类调用其子类的操作,通过子类对父类进行扩展增加新的行为,符合“开闭原则”。
    5. 模板模式的不足
    6. 每个不同的实现都需要定义一个子类,会导致类的个数增加,系统更加庞大。