模板方法模式
- 模板方法模式定义:
- 使用场景
- 角色定义
- 抽象模板: 为抽象模板,它的方法分为两类AbstractClass
- 1. 基本方法: 也叫做基本操作,是由子类实现的方法,并且在模板方法被调用。
- 2. 模板方法: 可以有一个或几个,一般是一个具体方法,也就是一个框架,实现对基本方法的调度,完成固定的逻辑
- 3. 为了防止恶意操作,一般模板方法都会加上 final 关键字,不允许被覆写。
- 具体模板: 实现父类所定义的一个或多个抽象方法,也就是父类定义的基本方法在子类中得以实现。
- 需求背景
- 定义用户行为日志基类(UserBehaviorLogger )
- 定义用户登录行为子类(LoginLogger )
- 定义用户涉及现金交易子类(CashTransactionLogger )
- 定义用户领取活动优惠券子类(CouponReceiveLogger )
- 测试示例
- 示例分析
模板方法模式定义:
定义一个操作中算法的框架,将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤
使用场景
- 多个子类有公有的方法,并且逻辑基本相同时
- 重要、复杂的算法,可以把核心算法设计为模板方法,周边的相关细节功能则由各个子类实现。
- 重构时,模板方法模式是一个经常使用的模式,把相同的代码抽取到父类中,约束其行为。
角色定义
抽象模板: 为抽象模板,它的方法分为两类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 {@Overrideprotected String getLogFormat() {return "User %s logged in at %s";}
}
定义用户涉及现金交易子类(CashTransactionLogger )
public class CashTransactionLogger extends UserBehaviorLogger {@Overrideprotected String getLogFormat() {return "User %s made a cash transaction at %s";}
}
定义用户领取活动优惠券子类(CouponReceiveLogger )
public class CouponReceiveLogger extends UserBehaviorLogger {@Overrideprotected 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");}
示例分析
- 在这个示例中,我们定义了一个抽象类 UserBehaviorLogger,它有一个抽象方法 getLogFormat(),用于获取当前用户行为类型对应的日志格式。
- 具体的行为日志记录器,如 LoginLogger、CashTransactionLogger 和 CouponReceiveLogger,都继承自 UserBehaviorLogger 并实现了 getLogFormat() 方法,用于返回对应的日志格式。
- 在基类 log() 方法中,我们根据当前用户行为类型获取对应的日志格式,并使用 String.format() 方法格式化日志内容,最终将日志保存到数据库中。
- 使用时,我们可以根据不同的用户行为类型创建对应的日志记录器,并调用 log() 方法记录日志
- 这样,我们就可以根据不同的用户行为类型使用不同的日志格式进行记录了。同时,由于使用了模板方法模式,我们也将日志记录的具体实现细节下推到了子类中,使得代码更加清晰和易于维护。