策略模式

本文深入探讨了策略模式的概念,一种设计模式,它允许算法在运行时互换,减少了算法类和使用算法类之间的耦合。通过具体例子展示了如何通过一个context类使不同算法可以互相替换,同时保持代码的灵活性和可测试性。

策略模式

定义一系列相同名称不同实现的算法(策略),通过一个context类使不同算法可以互相替换,而不影响使用算法的程序。

实现

public class Strategy {
    public static void main(String[] args) {
        ActivityContext activityContext = new ActivityContext(new DiscountActivity(0.8));
        System.out.println(activityContext.activity(800));
        ActivityContext activityContext1 = new ActivityContext(new ReturnCashActivity(300,50));
        System.out.println(activityContext1.activity(800));
    }
}

/**
 * 活动接口
 */
interface Activity{
    double activity(double originPrice);
}

/**
 * 打折活动
 */
class DiscountActivity implements Activity{

    private double discount;

    public DiscountActivity(double discount) {
        this.discount = discount;
    }
    public double activity(double originPrice) {
        return originPrice * discount;
    }
}
/**
 * 满减活动
 */
class ReturnCashActivity implements Activity{

    private double totalPrice;
    private double returnPrice;

    public ReturnCashActivity(double totalPrice, double returnPrice) {
        this.totalPrice = totalPrice;
        this.returnPrice = returnPrice;
    }

    public double activity(double originPrice) {
        double allPrice = (int)(originPrice / totalPrice) * returnPrice;
        return originPrice - allPrice;
    }
}

/**
 * 活动上下文
 */
class ActivityContext{
    private Activity activity;

    public ActivityContext(Activity activity) {
        this.activity = activity;
    }

    public double activity(double originPrice){
        return activity.activity(originPrice);
    }
}
复制代码

优点(大话设计模式)

  • 减少各种算法类和使用算法类的耦合
  • 算法类(strategy)为上下文类(Context)定义了可供重用的算法或行为,继承有助于析取出这些算法的公共功能
  • 简化了单元测试,每个算法都有自己的类,可以通过自己的接口单独测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值