模板方法模式

模板方法模式定义:

定义一个操作中算法的框架,将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤

使用场景

  1. 多个子类有公有的方法,并且逻辑基本相同时
  2. 重要、复杂的算法,可以把核心算法设计为模板方法,周边的相关细节功能则由各个子类实现。
  3. 重构时,模板方法模式是一个经常使用的模式,把相同的代码抽取到父类中,约束其行为。

角色定义

抽象模板: 为抽象模板,它的方法分为两类AbstractClass

1. 基本方法: 也叫做基本操作,是由子类实现的方法,并且在模板方法被调用。
2. 模板方法: 可以有一个或几个,一般是一个具体方法,也就是一个框架,实现对基本方法的调度,完成固定的逻辑
3. 为了防止恶意操作,一般模板方法都会加上 final 关键字,不允许被覆写。

具体模板: 实现父类所定义的一个或多个抽象方法,也就是父类定义的基本方法在子类中得以实现。

需求背景

使用模板方法模式,实现在项目当中用户的不同行为日志处理,比如用户登录、现金交易、领取活动优惠券、注意不同用户行为日志格式不一样需要下推到子类实现记录到数据库。

定义用户行为日志基类(UserBehaviorLogger )

public abstract class UserBehaviorLogger {
    protected abstract String getLogFormat();

    public void log(String userId, String behavior) {
        String log = String.format(getLogFormat(), userId, behavior);
        saveLogToDatabase(log);
    }

    private void saveLogToDatabase(String log) {
        // 将日志保存到数据库中
        // ...
    }
}

定义用户登录行为子类(LoginLogger )

public class LoginLogger extends UserBehaviorLogger {
    @Override
    protected String getLogFormat() {
        return "User %s logged in at %s";
    }
}

定义用户涉及现金交易子类(CashTransactionLogger )

public class CashTransactionLogger extends UserBehaviorLogger {
    @Override
    protected String getLogFormat() {
        return "User %s made a cash transaction at %s";
    }
}

定义用户领取活动优惠券子类(CouponReceiveLogger )

public class CouponReceiveLogger extends UserBehaviorLogger {
    @Override
    protected String getLogFormat() {
        return "User %s received a coupon at %s";
    }
}

测试示例

    public static void main(String[] args) {
        UserBehaviorLogger logger = new LoginLogger();
        logger.log("123456", "2022-01-01 10:00:00");

        logger = new CashTransactionLogger();
        logger.log("123456", "2022-01-01 11:00:00");

        logger = new CouponReceiveLogger();
        logger.log("123456", "2022-01-01 12:00:00");
    }

示例分析

  1. 在这个示例中,我们定义了一个抽象类 UserBehaviorLogger,它有一个抽象方法 getLogFormat(),用于获取当前用户行为类型对应的日志格式。
  2. 具体的行为日志记录器,如 LoginLogger、CashTransactionLogger 和 CouponReceiveLogger,都继承自 UserBehaviorLogger 并实现了 getLogFormat() 方法,用于返回对应的日志格式。
  3. 在基类 log() 方法中,我们根据当前用户行为类型获取对应的日志格式,并使用 String.format() 方法格式化日志内容,最终将日志保存到数据库中。
  4. 使用时,我们可以根据不同的用户行为类型创建对应的日志记录器,并调用 log() 方法记录日志
  5. 这样,我们就可以根据不同的用户行为类型使用不同的日志格式进行记录了。同时,由于使用了模板方法模式,我们也将日志记录的具体实现细节下推到了子类中,使得代码更加清晰和易于维护。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Run,boy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值