首页 > 代码库 > 设计模式 - 模板方法模式
设计模式 - 模板方法模式
定义:在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中。
模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。
角色:
抽象类(AbstractClass):实现了模板方法,定义了算法的骨架。
具体类(ConcreteClass):实现抽象类中的抽象方法,已完成完整的算法。
代码示例:抽象类定义了整个从做饭到吃饭最后清理的流程,子类是具体的不同的方式。
抽象类:定义骨架
package com.template; public abstract class AbstractEat { // 模板方法里面定义一连串的步骤 final void eatProcess(){ cook(); eat(); pack(); } abstract void cook(); abstract void eat(); // 共有的相同操作,父类直接实现,不须子类覆盖 final void pack(){ System.out.println("餐后清理。。。"); } }
具体类:
1、中餐
package com.template; public class ChineseFood extends AbstractEat { @Override void cook() { System.out.println("中餐做饭。。。"); } @Override void eat() { System.out.println("中餐吃法。。。"); } }
2、西餐
package com.template; public class WesternFood extends AbstractEat { @Override void cook() { System.out.println("西餐做饭。。。"); } @Override void eat() { System.out.println("西餐吃法。。。"); } }
测试类:
package com.template; public class TestTemplate { public static void main(String[] args) { AbstractEat c = new ChineseFood(); c.eatProcess(); AbstractEat w = new WesternFood(); w.eatProcess(); } }
总结:
1、模板方法可以提供代码的复用,把具体实现推迟到子类中。
2、为防止子类覆盖方法,可以将方法定义为final。
3、模板方法模式和策略模式都可以封装算法和行为,一个用继承,一个用组合。
设计模式 - 模板方法模式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。