大话设计模式——18.策略模式(Strategy Pattern)

简介

是一系列算法的封装,即做的事情相同(方法名称相同)但是实现的方式不同,以相同方式调用所有的算法,减少算法与使用算法的耦合。直接调用方法。

UML图

在这里插入图片描述

应用场景
  • Java AWT中的LayoutManager(布局管理器)
  • 系统中存在多个类,它们的区别仅在于它们的行为
  • 不希望暴露复杂与算法有关的数据结构
  • Java中Comparator 接口常用的 compare()方法

示例

电商平台会经常进行商品优惠活动,对商品或订单价格进行改动

  1. 商品
public class Product {

    /**
     * 产品价格
     */
    private double price;

    /**
     * 产品名称
     */
    private String productName;

    public Product(double price, String productName) {
        this.price = price;
        this.productName = productName;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    public String getProductName() {
        return productName;
    }

    public void setProductName(String productName) {
        this.productName = productName;
    }
}
  1. 策略:活动优惠策略
public interface Strategy {

    /**
     * 计算商品价格
     *
     * @param product
     * @return
     */
    double computePrice(Product product);
}

没有活动:

public class NormalActivity implements Strategy {

    @Override
    public double computePrice(Product product) {
        return product.getPrice();
    }
}

打折活动:

public class DiscountActivity implements Strategy {

    private double discount;

    public DiscountActivity(double discount) {
        this.discount = discount;
    }

    @Override
    public double computePrice(Product product) {
        return product.getPrice() * discount;
    }
}

代金券活动:

public class VoucherActivity implements Strategy {

    /**
     * 代金券
     */
    private double voucher;


    public VoucherActivity(double voucher) {
        this.voucher = voucher;
    }

    @Override
    public double computePrice(Product product) {
        return product.getPrice() > voucher ? product.getPrice() - voucher : 0;
    }
}
  1. 活动上下文:选择适当的活动促销策略
public class PromotionContext {

    /**
     * 策略
     */
    private Strategy strategy;


    public PromotionContext(Strategy strategy) {
        this.strategy = strategy;
    }

    public double executeStrategy(Product product) {
        return this.strategy.computePrice(product);
    }
}
  1. 运行
public class Main {

    public static void main(String[] args) {

        // 创建商品
        Product phone = new Product(1999, "手机");

        // 促销策略
        PromotionContext promotionContext;

        // 原价
        promotionContext = new PromotionContext(new NormalActivity());
        System.out.println("原价:" + promotionContext.executeStrategy(phone));

        // 8折优惠
        promotionContext = new PromotionContext(new DiscountActivity(0.8));
        System.out.println("优惠价格:" + promotionContext.executeStrategy(phone));

        // 2000代金券
        promotionContext = new PromotionContext(new VoucherActivity(2000));
        System.out.println("券后价格:" + promotionContext.executeStrategy(phone));

    }
}

在这里插入图片描述

总结

  • 优点:

    • 满足开闭原则,当增加具体策略时,不需要修改上下文代码
    • 避免使用过多的条件判断,过多的条件判断语句不利于系统可维护性,扩展性和灵活性
  • 缺点

    • 策略类可能过多可能导致膨胀,复用性较小
  • 18
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值