模板和策略设计模式联合使用的demo

在联合使用模板设计模式和策略设计模式时,我们可以定义一个模板类,该类包含了一些固定步骤的算法,并在其中使用策略接口来允许子类提供不同的实现。这样,我们可以在不改变算法结构的情况下改变算法中的某些步骤。

以下是一个简单的例子,展示了如何联合使用模板设计模式和策略设计模式:

首先,我们定义一个策略接口:

java 复制代码
public interface PaymentStrategy {
    void pay(double amount);
}

然后,我们实现两种支付策略:

java 复制代码
public class CreditCardPayment implements PaymentStrategy {
    @Override
    public void pay(double amount) {
        System.out.println("Paying with credit card for amount: " + amount);
    }
}

public class BankTransferPayment implements PaymentStrategy {
    @Override
    public void pay(double amount) {
        System.out.println("Paying with bank transfer for amount: " + amount);
    }
}

接下来,我们定义一个模板类,它接受一个支付策略对象,并在其算法中使用这个策略对象:

java 复制代码
public abstract class PaymentProcessor {
    private PaymentStrategy strategy;

    public PaymentProcessor(PaymentStrategy strategy) {
        this.strategy = strategy;
    }

    public void processPayment(double amount) {
        // 固定步骤1:准备支付环境
        prepareEnvironment();

        // 策略步骤:执行支付
        strategy.pay(amount);

        // 固定步骤2:支付后处理
        postProcessPayment();
    }

    // 模板方法,固定步骤的实现
    protected void prepareEnvironment() {
        System.out.println("Preparing payment environment...");
    }

    // 模板方法,固定步骤的实现
    protected void postProcessPayment() {
        System.out.println("Payment processed successfully!");
    }
}

最后,我们创建具体的支付处理器类,它们继承自PaymentProcessor并传入具体的支付策略:

java 复制代码
public class CreditCardPaymentProcessor extends PaymentProcessor {
    public CreditCardPaymentProcessor() {
        super(new CreditCardPayment());
    }

    // 可以重写固定步骤,如果需要的话
    @Override
    protected void prepareEnvironment() {
        System.out.println("Verifying credit card details...");
    }
}

public class BankTransferPaymentProcessor extends PaymentProcessor {
    public BankTransferPaymentProcessor() {
        super(new BankTransferPayment());
    }

    // 可以重写固定步骤,如果需要的话
    @Override
    protected void prepareEnvironment() {
        System.out.println("Checking bank account balance...");
    }
}

现在,我们可以使用这些支付处理器来执行支付:

java 复制代码
public class Main {
    public static void main(String[] args) {
        PaymentProcessor creditCardProcessor = new CreditCardPaymentProcessor();
        creditCardProcessor.processPayment(100.0);

        PaymentProcessor bankTransferProcessor = new BankTransferPaymentProcessor();
        bankTransferProcessor.processPayment(200.0);
    }
}

输出结果:

csharp 复制代码
Verifying credit card details...
Paying with credit card for amount: 100.0
Payment processed successfully!
Checking bank account balance...
Paying with bank transfer for amount: 200.0
Payment processed successfully!

在这个例子中,PaymentProcessor是模板类,它定义了支付处理的算法骨架,而PaymentStrategy是策略接口,允许我们提供不同的支付实现。CreditCardPaymentProcessorBankTransferPaymentProcessor是具体的支付处理器,它们通过组合PaymentProcessor和具体的策略对象来提供不同的支付功能。

相关推荐
咋吃都不胖lyh10 分钟前
RESTful API 调用详解(零基础友好版)
后端·restful
源代码•宸14 分钟前
Golang原理剖析(map)
经验分享·后端·算法·golang·哈希算法·散列表·map
小镇cxy23 分钟前
Ragas 大模型评测框架深度调研指南
后端
qq_2562470524 分钟前
拯救“复读机”:从小模型死循环看 Logits 到 Dist 的全流程采样机制
后端
七八星天26 分钟前
Exception异常与异常处理(.Net)
后端
千寻技术帮29 分钟前
10340_基于Springboot的游戏网站
spring boot·后端·游戏·vue·商城
于顾而言34 分钟前
【一文带你搞懂】漏扫核弹Nuclei
后端
WX-bisheyuange40 分钟前
基于SpringBoot的诊疗预约平台
java·spring boot·后端·毕业设计
SimonKing43 分钟前
基于Netty的WebSocket客户端
java·后端·程序员
麦兜*1 小时前
Spring Boot 整合 Spring Data JPA 入门:只需注解,告别 SQL
spring boot·后端·sql