揭秘策略模式:如何用Java设计模式轻松切换算法?

简介: 【8月更文挑战第30天】设计模式是解决软件开发中特定问题的可重用方案。其中,策略模式是一种常用的行为型模式,允许在运行时选择算法行为。它通过定义一系列可互换的算法来封装具体的实现,使算法的变化与客户端分离。例如,在电商系统中,可以通过定义 `DiscountStrategy` 接口和多种折扣策略类(如 `FidelityDiscount`、`BulkDiscount` 和 `NoDiscount`),在运行时动态切换不同的折扣逻辑。这样,`ShoppingCart` 类无需关心具体折扣计算细节,只需设置不同的策略即可实现灵活的价格计算,符合开闭原则并提高代码的可维护性和扩展性。

设计模式是在软件开发中用来解决特定问题的可重用解决方案。它们是在众多项目中反复出现的问题的通用解决方法,被广泛地认可和应用。今天,我们将深入探讨一种非常有用的行为型设计模式——策略模式,它允许在运行时选择算法的行为。

策略模式定义了一系列算法,并将每一个算法封装起来,使它们可以互相替换。策略模式让算法的变化独立于使用算法的客户端。这意味着,如果你有一些不同的业务算法或逻辑,并且希望在运行时根据条件动态切换这些逻辑,那么策略模式是一个非常好的选择。

让我们通过一个简单的例子来看看策略模式是如何工作的。假设我们正在创建一个电商系统,其中有不同类型的用户折扣策略。

首先,我们定义一个策略接口 DiscountStrategy,它包含了一个方法 applyDiscount

interface DiscountStrategy {
   
    double applyDiscount(double price);
}

然后,我们实现几个具体的折扣策略类,比如 FidelityDiscountBulkDiscountNoDiscount

class FidelityDiscount implements DiscountStrategy {
   
    @Override
    public double applyDiscount(double price) {
   
        return price * 0.9; // 10% off for fidelity members
    }
}

class BulkDiscount implements DiscountStrategy {
   
    @Override
    public double applyDiscount(double price) {
   
        return price * 0.85; // 15% off for buying in bulk
    }
}

class NoDiscount implements DiscountStrategy {
   
    @Override
    public double applyDiscount(double price) {
   
        return price; // no discount
    }
}

接下来,我们需要一个上下文类 ShoppingCart,它将使用 DiscountStrategy

class ShoppingCart {
   
    private DiscountStrategy strategy;

    public void setStrategy(DiscountStrategy strategy) {
   
        this.strategy = strategy;
    }

    public double getFinalPrice(double price) {
   
        return strategy.applyDiscount(price);
    }
}

现在,我们可以在运行时改变 ShoppingCart 使用的折扣策略:

public class StrategyPatternDemo {
   
    public static void main(String[] args) {
   
        ShoppingCart cart = new ShoppingCart();

        cart.setStrategy(new FidelityDiscount());
        System.out.println("Total with fidelity discount: " + cart.getFinalPrice(100)); // Output: 90.0

        cart.setStrategy(new BulkDiscount());
        System.out.println("Total with bulk discount: " + cart.getFinalPrice(100)); // Output: 85.0

        cart.setStrategy(new NoDiscount());
        System.out.println("Total with no discount: " + cart.getFinalPrice(100)); // Output: 100.0
    }
}

在这个例子中,ShoppingCart 不需要知道具体的折扣计算细节,它只需要知道每个折扣策略都遵循相同的 DiscountStrategy 接口。这样,新增或者更换折扣策略时,我们无需修改 ShoppingCart 类的代码,符合开闭原则。

策略模式非常适合用于实现不同的业务规则或算法,同时保持客户端代码的简洁性和扩展性。在实际应用中,你可以根据具体需求将策略模式应用于多种场合,例如创建不同类型的日志记录器、实现不同的缓存策略等。通过这种方式,策略模式可以帮助我们编写更加灵活且可维护的代码。

相关文章
|
1月前
|
设计模式 算法 Kotlin
Kotlin - 改良设计模式 - 策略模式
Kotlin - 改良设计模式 - 策略模式
48 4
|
24天前
|
设计模式 消息中间件 搜索推荐
Java 设计模式——观察者模式:从优衣库不使用新疆棉事件看系统的动态响应
【11月更文挑战第17天】观察者模式是一种行为设计模式,定义了一对多的依赖关系,使多个观察者对象能直接监听并响应某一主题对象的状态变化。本文介绍了观察者模式的基本概念、商业系统中的应用实例,如优衣库事件中各相关方的动态响应,以及模式的优势和实际系统设计中的应用建议,包括事件驱动架构和消息队列的使用。
|
26天前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
41 1
|
1月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
29 2
|
1月前
|
设计模式 Java 数据库连接
Java编程中的设计模式:单例模式的深度剖析
【10月更文挑战第41天】本文深入探讨了Java中广泛使用的单例设计模式,旨在通过简明扼要的语言和实际示例,帮助读者理解其核心原理和应用。文章将介绍单例模式的重要性、实现方式以及在实际应用中如何优雅地处理多线程问题。
38 4
|
1月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
47 2
|
2月前
|
设计模式 Java 程序员
[Java]23种设计模式
本文介绍了设计模式的概念及其七大原则,强调了设计模式在提高代码重用性、可读性、可扩展性和可靠性方面的作用。文章还简要概述了23种设计模式,并提供了进一步学习的资源链接。
54 0
[Java]23种设计模式
|
1月前
|
设计模式 JavaScript Java
Java设计模式:建造者模式详解
建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。
|
2月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文通过游泳运动员的案例,介绍策略模式及其在Kotlin中的改良应用,利用高阶函数简化代码结构,提高灵活性。
38 3
|
2月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文介绍策略模式在Kotlin中的应用,通过游泳运动员的例子,展示如何使用接口和高阶函数实现策略模式,使代码更简洁、灵活。
34 2