重学设计模式(八)—— 模板方法模式

模板方法定义了一个算法的步骤,并允许子类为一个或者多个步骤提供实现。

说起模板方法模式,笔者就想起刚开始编写数据库操作代码的场景,在无框架支持的前提下,每次跟数据库的交互都要加载驱动、创建连接、准备语句、执行语句、结果处理、关闭连接、异常处理等步骤。但是仔细观察,很多操作其实都是一样的,因此在Spring中,引入了JDBCTemplate概念,为数据库操作指定了模板、不同厂商的数据库只要实现相应的模板中的接口便可实现数据库操作。

模板方法模式的类图如下:

这里写图片描述

我们定义一个模板方法:

public abstract class AbstractMethod {
    //模板方法
    final void templateMethod(){
        System.out.println("调用模板方法开始");
        subMethod();
        System.out.println("调用模板方法结束");
    }

    //抽象方法,等待子类实现
    public abstract void subMethod();
}

我们再定义两个子类:

public class ConcreteMethod01 extends AbstractMethod {
    public void subMethod() {
        System.out.println("这是ConcreteMethod01类的具体实现");
    }
}

public class ConcreteMethod02 extends AbstractMethod {
    public void subMethod() {
        System.out.println("这是ConcreteMethod02类的具体实现");
    }
}

最后我们来编写测试类:

public class TemplateMethodTest {
    public static void main(String[] args) {
        ConcreteMethod01 c1 = new ConcreteMethod01();
        ConcreteMethod02 c2 = new ConcreteMethod02();

        c1.templateMethod();
        System.out.println("\n====================\n");
        c2.templateMethod();
    }
}

我们看一下运行结果:
这里写图片描述

模板方法将相同部分的代码放在抽象的父类中,提高了代码的复用性,同时通过一个父类调用其子类的操作,通过对子类的扩展增加新的行为,实现了反向控制,符合“开闭原则”,但是这也会导致类的个数增加,从而增加了系统实现的复杂度。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值