![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsISN5QjMxkjM0ETMxATM1EDMy8CX0Vmbu4GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.jpg)
思想:定 义一系列的算法,把它们一个个封装起来, 并 且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。
场景:该 模式实际上也可以理解为一种Bridge模式的变种。只是它突出的是,一般当我们把一个类或者一组 类的一些代码独立成一个Strategy类的时候,我们可能会为同样接口的这些算法定义多个接口一 致,但是实现方法不同的版本,并在需要的时候灵活的替换这些算法。
实现:实 现方式同Bridge模式。
重构成本:中。
//文本替换策略
abstract class TextStrategy {
protected String text;
public TextStrategy(String text) {
this.text = text;
}
public abstract String replace();
}
//替换算法1:将文本中"@[email protected]"替换为"@n"
class StrategyOne extends TextStrategy {
public StrategyOne(String text) {
super(text);
}
public String replace() {
System.out.println(“StrategyOne:”);
String result = text.replaceAll("@[email protected]", "@n"));
return result;
}
}
//替换算法2:将文本中"@n"替换为"@[email protected]"
class StrategyTwo extends TextStrategy {
public StrategyTwo(String text) {
super(text);
}
public String replace() {
System.out.println(“StrategyTwo:”);
String result = text.replaceAll(“@n", "@[email protected]"));
return result;
}
}
public class TextCharChange {
public static void replace(TextStrategy strategy) {
strategy.replace();
}
public static void main(String[] args){
String testText1 = "This is a test [email protected] Oh! Line Return[email protected]";
String testText2 = This is a test [email protected]@n Oh! Line [email protected]@n";
TextCharChange.replace(new StrategyOne(testText2));
TextCharChange.replace(new StrategyTwo(testText1));
}
}
State状态模式和Strategy策略模式非常类似,但是有如下区别:
(1).State状态模式重点在于设定状态变化,根据状态,返回相应的响应。
(2).Strategy策略模式重点在于根据需求直接采用设定的策略,即根据场景选择合适的处理算法,而不需要改变状态。
JDK中策略模式的应用:
•java.util.concurrent.ThreadPoolExecutor.AbortPolicy
•java.util.concurrent.ThreadPoolExecutor.CallerRunsPolicy
•java.util.concurrent.ThreadPoolExecutor.DiscardOldestPolicy
•java.util.concurrent.ThreadPoolExecutor.DiscardPolicy
•java.util.Comparator