Java设计模式实战:策略模式、工厂模式、模板模式组合使用

Java设计模式实战:策略模式、工厂模式、模板模式组合使用

在软件开发中,设计模式是解决特定问题的成熟模板。它们可以帮助我们写出更灵活、更可维护的代码。本文将通过一个充电场景为例,展示如何将策略模式(Strategy Pattern)、工厂模式(Factory Pattern)和模板方法模式(Template Method Pattern)结合起来,以实现一个灵活且可扩展的充电系统。

策略模式

java 复制代码
public interface ChargingStrategy {
    void charge();

    String getSign();
}

这个接口定义了所有充电策略必须实现的charge方法和getSign方法,后者用于返回策略的唯一标识。

模板模式

模板方法模式是一种行为设计模式,它在方法中定义了一个算法的框架,将一些步骤延迟到子类中实现。这让我们可以在不改变算法结构的情况下重新定义算法的某些步骤。在示例中,ChargingTemplate类就是一个模板方法的实现。

java 复制代码
public abstract class ChargingTemplate implements ChargingStrategy {

    /**
     * 模板方法,定义充电的步骤
     */
    @Override
    public final void charge() {
        securityCheck();
        initiateCharging();
        chargingSettlement();
    }

    /**
     * 安全检查
     */
    private void securityCheck() {
        System.out.println("Security check completed.");
    }

    /**
     * 启动充电
     */
    protected abstract void initiateCharging();

    /**
     * 充电结算
     */
    private void chargingSettlement() {
        System.out.println("Charging process finalized. Thank you!");
    }
}

这个抽象类定义了充电的步骤,包括安全检查、启动充电和充电结算。initiateCharging方法是一个抽象方法,需要在具体的充电策略中实现。

工厂模式

工厂模式是一种创建型设计模式,它提供了一个创建对象的接口,让子类决定实例化哪一个类。工厂模式使一个类的实例化延迟到其子类。在我们的充电系统中,ChargingFactory类就是一个工厂模式的实现。

java 复制代码
@Component
public class ChargingFactory {
    private final Map<String, ChargingStrategy> strategies = new HashMap<>();

    @Autowired
    public ChargingFactory(List<ChargingStrategy> strategyList) {
        for (ChargingStrategy strategy : strategyList) {
            registerStrategy(strategy);
        }
    }

    private void registerStrategy(ChargingStrategy strategy) {
        strategies.put(strategy.getSign(), strategy);
    }

    public ChargingStrategy getChargingStrategy(String type) {
        ChargingStrategy strategy = strategies.get(type);
        if (strategy == null) {
            throw new IllegalArgumentException("Unknown charging type: " + type);
        }
        return strategy;
    }
}

这个工厂类负责注册和获取充电策略实例。它通过一个map集合来管理所有可用的充电策略,并根据传入的类型标识来返回相应的策略实例。

策略类

常规充电

java 复制代码
@Component("RegularCharging")
public class RegularCharging extends ChargingTemplate {
    @Override
    protected void initiateCharging() {
        System.out.println("Start regular charging.");
    }

    @Override
    public String getSign() {
        return "REGULAR";
    }
}

快速充电

java 复制代码
@Component("FastCharging")
public class FastCharging extends ChargingTemplate {
    @Override
    protected void initiateCharging() {
        System.out.println("Start fast charging.");
    }

    @Override
    public String getSign() {
        return "FAST";
    }
}

超级快充

java 复制代码
@Component("SuperFastCharging")
public class SuperFastCharging extends ChargingTemplate {
    @Override
    protected void initiateCharging() {
        System.out.println("Start super fast charging.");
    }

    @Override
    public String getSign() {
        return "SUPERFAST";
    }
}

每个策略类都实现了initiateCharging方法,并提供了一个唯一的标识符。这些类被注册到ChargingFactory中,以便可以根据需要获取和使用。

结论

通过将策略模式、工厂模式和模板方法模式结合起来,我们创建了一个灵活且可扩展的充电系统。这种设计当我们增加策略时只需要添加策略类即可,不需要额外操作。同时,它也保持了代码的清晰和可维护性。这种模式的组合是解决复杂问题的强大工具,值得在实际项目中广泛应用。

相关推荐
敲代码的彭于晏7 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev8 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia1 天前
Mybatis的日志输入
java
亦暖筑序1 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6751 天前
字节跳动国际支付-后端开发-三面面经
java