zoukankan      html  css  js  c++  java
  • Java之模板方法模式(Template Method)

    1. 概念:定义一个算法的骨架,而将一些实现步骤延迟到子类中。

        把不变的行为搬到超类,去除子类中重复的代码来体现他的优势。

    2. UML图:

    3.代码:

    public abstract class Templete 
    {  
      private void beforeOperation()
      {  
        System.out.println("This acton before the operation!");  
      }  
       
      private void afterOperation()
      {  
        System.out.println("This acton after the operation!");  
      }  
       
      //需要推迟到子类(实现类) 中执行  
      protected abstract void operation();  
    
      public void topOperation()
      {  
        beforeOperation();  
    
        operation();  
    
        afterOperation();  
      }  
    }  
    
    public class TempleteImpl extends Templete 
    {  
      protected void operation() 
      {  
        System.out.println("The operation action is executed in the method of ServiceA instance! ");  
      }  
    }  
    
    public class TempletTest 
    {  
      public static void main(String[] args) 
      {  
        Templete templete = new TempleteImpl();  
        templete.topOperation();  
      }  
    }  
    

      

    4.应用场景:

    1) 一次性实现一个算法的不变的部分,并将可变的行为留给子类来实现。

    2) 各子类中公共的行为应被提取出来并集中到一个公共父类中以避免代码重复。首先识别现有代码中的不同之处,并且将不同之处分离为新的操作。最后,用一个调用这些新的操作的模板方法来替换这些不同的代码。

     --------------------------------------------------------------------

    PS: 欢迎关注公众号"Devin说",会不定期更新Java相关技术知识。

    --------------------------------------------------------------------

  • 相关阅读:
    Solution to LeetCode Problem Set
    《Cracking the Coding Interview》读书笔记
    诗词收集——用于人文素养扫盲
    2015年清华大学计算机系考研总结
    编程知识大杂烩
    hihoCoder 1175:拓扑排序二
    Hackerrank
    Hackerrank
    LeetCode
    LeetCode
  • 原文地址:https://www.cnblogs.com/devinzhang/p/2304953.html
Copyright © 2011-2022 走看看