一、简介
所谓策略,可以看做是“算法”,就比如商家搞活动可能采用满减策略、打折策略、返利策略,每种策略都可以看作是一种“算法”。对于同一种商品,可以根据需要,随时替换使用不同的促销策略。
而策略模式就是定义了一组同类型的算法,将每个算法都封装成一个类,并且可以通过传入不同的参数,轻松的切换不同的算法来解决同一个问题
策略模式中主要有三类角色:
(1)Strategy(抽象策略)
通常是一个接口,主要负责定义每个具体策略必须具有的方法和属性
(2)ConcreteStrategy(具体策略)
主要是实现抽象策略接口,也就是实现具体的策略
(3)Context(上下文)
负责使用策略,它里面保存了一个具体策略角色的实例,并使用该实例去
实现对应的需求,起承上启下的作用,屏蔽高层模块对策略的直接访问,
封装可能存在的变化
策略模式的类图如下:
二、使用场景
一个项目中有很多类,它们定义了用来解决某一个问题的不同算法,如果我们不想使用多重条件选择语句来选择使用哪一个算法,这时就可以使用策略模式。
它的优点在于不必进行多重条件判断,算法可以自由切换使用,而且扩展性好,新增一个策略只需新增一个实现接口的类即可。 另外,它将策略的定义、创建、使用解耦,让每一部分不会过于复杂,提高了代码的可维护性。
如目前大多数app都有分享功能,我们可以分享到不同的地方,如QQ、微信、微博等等,虽然是同一个内容,但分享到不同的平台会有不同的处理方式,比如跳转到不同的app。
这时我们就可以使用策略模式,定义一个分享策略接口,让不同的具体分享策略实现这个接口,然后使用上下文封装某个策略的使用,通过传入不同的参数,使用不同的上下文。
三、举例
public class 策略模式 {
public static void main(String[] args) {
Share sha=new Share();
sha.share("QQ");
sha.share("WeChat");
sha.share("Sina");
}
}
//定义抽象策略接口
interface ShareStrategy{
void shareMethod();
}
//定义具体策略1
class ShareStrategyWithSina implements ShareStrategy{
@Override
public void shareMethod() {
System.out.println("分享到微博了");
}
}
//定义具体策略2
class ShareStrategyWithWeChat implements ShareStrategy{
@Override
public void shareMethod() {
System.out.println("分享到微信了");
}
}
//定义具体策略3
class ShareStrategyWithQQ implements ShareStrategy{
@Override
public void shareMethod() {
System.out.println("分享到QQ了");
}
}
//定义使用策略的上下文
class ShareContext{
ShareStrategy strategy=null;
public ShareContext(ShareStrategy strategy){
this.strategy=strategy;
}
public void share() {
strategy.shareMethod();
}
}
//分享功能
class Share{
private static HashMap<String,ShareContext>algs=new HashMap<>();
//静态代码块,先加载所有的策略
static{
algs.put("Sina", new ShareContext(new ShareStrategyWithSina()));
algs.put("WeChat", new ShareContext(new ShareStrategyWithWeChat()));
algs.put("QQ", new ShareContext(new ShareStrategyWithQQ()));
}
public void share(String type){
ShareContext context=null;
context=algs.get(type);
if(context!=null)context.share();
else System.out.println("分享失败");
}
}