工作中的设计模式 —— 策略模式

简介: 策略模式是一种行为设计模式,它能让你定义一系列算法,并将每种算法分别放入独立的类中,以使算法的对象能够相互替换。

前言


策略模式是一种行为设计模式,它能让你定义一系列算法,并将每种算法分别放入独立的类中,以使算法的对象能够相互替换。


使用场景

策略模式在工作中使用的相对是比较多的,像支付场景,计费场景,优惠场景,活动奖励、用户等级等等。

当然也有很多直白的说法,就是替换一大堆的 if else。

if (x == aaa) {
    // 200 行代码
} else if (x == bbb) {
    // 200 行代码
} else if (x == ccc) {
    // 200 行代码
}

按照上面的 if else 逻辑,其中 aaa、bbb、ccc 就是不同的策略。而使用策略模式的目的,就是当又增加了 ddd、eee 等等的时候,更方便的扩展。

这里以工作中遇到的场景举例:

这里选择使用理财储蓄场景中的计费策略举例: 在理财储蓄场景中,需要每日给用户发放利息,同时用户分为普通用户、持卡用户,他们有分别的利率以及计息方式。

网络异常,图片无法展示
|

很明显,在计费时要使用策略模式,按照以下模式进行开发。


使用方式

定义计算接口

public interface RevenueCalculator {
    RevenueDTO calculate(BigDecimal asset);
}


定义不同的计算实现

对外暴露的是一个接口,而具体的实现,则需要自己去扩展。下面展示了三个实现。

@Component
public class DefaultRevenueCalculator implements RevenueCalculator {
    @Override
    public RevenueDTO calculate(BigDecimal asset) {
        return null;
    }
}
@Component
public class StepRateGeneralRevenueCalculator implements RevenueCalculator {
    @Override
    public RevenueDTO calculate(BigDecimal asset) {
        return null;
    }
}
@Component
public class StepRateHoldCardRevenueCalculator implements RevenueCalculator {
    @Override
    public RevenueDTO calculate(BigDecimal asset) {
        return null;
    }
}

网络异常,图片无法展示
|

当然这里 StepRateHoldCardRevenueCalculator 和 StepRateGeneralRevenueCalculator 有抽象相同的业务逻辑,也可以抽出来一层工厂方法。

网络异常,图片无法展示
|

这些在这里都不是重点。

通过实现接口的方式,在后面有新的计费策略时,就写一个新的实现类就可以了。

现在的问题是,我如何确定哪个用户走那一套策略呢?


策略类

public enum UserTypeEnum implements BaseEnum {
    /**
     * OWealth 原始计息方式
     */
    DEFAULT_USER(-1, "原计息方式", "defaultRevenueCalculator"),
    /**
     * 普通用户
     */
    GENERAL_USER(0, "默认用户", "stepRateGeneralRevenueCalculator"),
    /**
     * 持卡用户
     */
    HOLD_CARD_USER(1, "持卡用户", "stepRateHoldCardRevenueCalculator"),
    ;
    // 省略代码
}
public class RevenueCalculatorFactory {
    public static RevenueCalculator getCalculator(UserTypeEnum userType) {
        return SpringContextHolder.getBean(userType.getServiceName());
    }
}

这里只是介绍了使用枚举维护用户类型和策略实现的关系,也可以在这里面写 if else 判断策略,或者维护在数据库中。

总结


本文介绍了在工作中使用策略模式,总结一下经常使用到的场景:

  1. 支付方式的选择:微信、支付宝、银联等等
  2. 计费策略不同:不同的用户计费方式不同(收费/运费等)
  3. 活动规则选择:不同的活动走不同计算的逻辑
  4. 计息方式不同:不同的用户(产品)计算利息的方式不同

...

更多的就需要小伙伴去发现和总结了。

渔、就在这里,能不能打到鱼,那就靠耐心了。 加油

目录
相关文章
|
3月前
|
设计模式 算法 Kotlin
Kotlin - 改良设计模式 - 策略模式
Kotlin - 改良设计模式 - 策略模式
63 4
|
12天前
|
设计模式 算法 开发者
「全网最细 + 实战源码案例」设计模式——策略模式
策略模式(Strategy Pattern)是一种行为型设计模式,用于定义一系列可替换的算法或行为,并将它们封装成独立的类。通过上下文持有策略对象,在运行时动态切换算法,提高代码的可维护性和扩展性。适用于需要动态切换算法、避免条件语句、经常扩展算法或保持算法独立性的场景。优点包括符合开闭原则、运行时切换算法、解耦上下文与策略实现、减少条件判断;缺点是增加类数量和策略切换成本。示例中通过定义抽象策略接口和具体策略类,结合上下文类实现动态算法选择。
47 8
「全网最细 + 实战源码案例」设计模式——策略模式
|
2月前
|
设计模式 存储 缓存
前端必须掌握的设计模式——策略模式
策略模式(Strategy Pattern)是一种行为型设计模式,旨在将多分支复杂逻辑解耦。每个分支类只关心自身实现,无需处理策略切换。它避免了大量if-else或switch-case代码,符合开闭原则。常见应用场景包括表单验证、风格切换和缓存调度等。通过定义接口和上下文类,策略模式实现了灵活的逻辑分离与扩展。例如,在国际化需求中,可根据语言切换不同的词条包,使代码更加简洁优雅。总结来说,策略模式简化了多条件判断,提升了代码的可维护性和扩展性。
|
3月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
59 1
|
3月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
57 2
|
3月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
59 2
|
4月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文通过游泳运动员的案例,介绍策略模式及其在Kotlin中的改良应用,利用高阶函数简化代码结构,提高灵活性。
55 3
|
4月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
77 3
|
4月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
本教程详细讲解Kotlin语法,适合深入学习。快速入门可参考“简洁”系列教程。本文介绍策略模式在Kotlin中的应用,通过游泳运动员的例子,展示如何使用接口和高阶函数实现策略模式,使代码更简洁、灵活。
42 2
|
4月前
|
设计模式 算法 Kotlin
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
Kotlin教程笔记(53) - 改良设计模式 - 策略模式
40 3

热门文章

最新文章