策略模式(strategy)

本文探讨了策略模式在CRM系统报价策略中的应用,通过分离算法和客户端调用,提高了代码的可维护性和扩展性。策略模式允许动态更换算法,实现对不同类型客户和订单量的灵活定价。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景:

某市场人员接单后的报价策略(CRM系统中常见的问题)

  1. 普通客户小批量报价
  2. 普通客户大批量报价
  3. 老客户小批量报价、
  4. 老客户大批量报价
    报价策略根据具体的情况来确定,及采用策略模式。报价策略根据具体的情况来确定,及采用策略模式。

本质:

分离算法,选择实现

常见开发场景

  • JAVASE中GUI编程中的布局管理。
  • Spring 框架中,Resource接口,资源访问策略。
  • javax.servlet.http.HttpServlet#service()

传统的实现:

实现起来比较容易,符合一般开发人员的思路,假如,类型特别多,算法比较复杂时,整个条件语句的代码就变得很长,难于维护。如果有新增类型,就需要频繁的修改此处的代码!
不符合开闭原则!

public double getPrice(String type, double price) {

		if (type.equals("普通客户小批量")) {
			System.out.println("不打折,原价");
			return price;
		} else if (type.equals("普通客户大批量")) {
			System.out.println("打九折");
			return price * 0.9;
		} else if (type.equals("老客户小批量")) {
			System.out.println("打八五折");
			return price * 0.85;
		} else if (type.equals("老客户大批量")) {
			System.out.println("打八折");
			return price * 0.8;
		}
		return price;
	}

策略模式实现:

1.定义接口

public interface Strategy {
	public double getPrice(double  standardPrice);
}

新客户1

public class NewCustomerFewStrategy implements Strategy {
	@Override
	public double getPrice(double standardPrice) {
		System.out.println("不打折,原价");
		return standardPrice;
	}
}

新客户2

public class NewCustomerManyStrategy implements Strategy {

	@Override
	public double getPrice(double standardPrice) {
		System.out.println("打九折");
		return standardPrice*0.9;
	}

}

老客户1

public class OldCustomerFewStrategy implements Strategy {

	@Override
	public double getPrice(double standardPrice) {
		System.out.println("打八五折");
		return standardPrice*0.85;
	}
}

老客户2

public class OldCustomerManyStrategy implements Strategy {

	@Override
	public double getPrice(double standardPrice) {
		System.out.println("打八折");
		return standardPrice*0.8;
	}
}

策略

负责和具体的策略类交互

  • 这样的话,具体的算法和直接的客户端调用分离了,使得算法可以独立于客户端独立的变化。
  • 如果使用spring的依赖注入功能,还可以通过配置文件,动态的注入不同策略对象,动态的切换不同的算法.
public class Context {
	private Strategy strategy;	//当前采用的算法对象

	//可以通过构造器来注入
	public Context(Strategy strategy) {
		super();
		this.strategy = strategy;
	}
	//可以通过set方法来注入
	public void setStrategy(Strategy strategy) {
		this.strategy = strategy;
	}
	
	public void pringPrice(double s){
		System.out.println("您该报价:"+strategy.getPrice(s));
	}
}

测试类:

根据传递过去的对象,选择不同的策略

public class Client {
	public static void main(String[] args) {
		Strategy s1 = new OldCustomerManyStrategy();
		Context ctx = new Context(s1);
		ctx.pringPrice(956);
	}
}

类的结构图:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值