设计模式之策略模式


main
=================================================================================
package com.strategy.com;

public class TestStrategy {

/**
* @param args

封装类:也叫上下文,对策略进行二次封装,目的是避免高层模块对策略的直接调用。
抽象策略:通常情况下为一个接口,当各个实现类中存在着重复的逻辑时,则使用抽象类来封装这部分公共的代码,此时,策略模式看上去更像是模版方法模式。
具体策略:具体策略角色通常由一组封装了算法的类来担任,这些类之间可以根据需要自由替换。
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
StrategyI strategy1 = new ConcreteStrategy1();
StrategyI strategy2 = new ConcreteStrategy2();
Context context = null;
System.out.println("执行策略一");
context = new Context(strategy1);
context.excute();
System.out.println("执行策略二");
context = new Context(strategy2);
context.excute();
}

}
策略抽象类
==============================================================================
package com.strategy.com;

public interface StrategyI {
void doSomething();
}
策略具体类1
=================================================================================
package com.strategy.com;

public class ConcreteStrategy1 implements StrategyI {

@Override
public void doSomething() {
// TODO Auto-generated method stub
System.out.println("这是策略一");
}

}
策略具体类2
==============================================================================
package com.strategy.com;

public class ConcreteStrategy2 implements StrategyI {

@Override
public void doSomething() {
// TODO Auto-generated method stub
System.out.println("这是策略二");
}

}

封装类
===============================================================================
package com.strategy.com;

public class Context {
private StrategyI strategy;

public Context(StrategyI strategy) {
this.strategy = strategy;
}

public void excute() {
strategy.doSomething();
}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值