策略模式让用户可以选择执行一个动作的方法,也就是说,用户可以选择不同的策略来进行操作。例如排序,用户可以选择较大的放前面,也可以选择较小的放前面,或者是按照自定义的顺序来放,这个自定义的顺序必须按照一定的策略得到,用户必须自己实现这样的策略。
还是来看一个例子吧,这个例子是对一个字符串数组进行排序的,按照字符串长度的不同来进行排序。
package strategy; import java.util.*; class StrategyOne implements Comparator<Object>{ @Override public int compare(Object o1, Object o2) { // TODO Auto-generated method stub String first = (String)o1; String second = (String)o2; if (first.length()<second.length()) return -1; else if (first.length()>second.length()) return 1; else return 0; } } class StrategyTwo implements Comparator<Object>{ @Override public int compare(Object o1, Object o2) { // TODO Auto-generated method stub String first = (String)o1; String second = (String)o2; if (first.length()>second.length()) return -1; else if (first.length()<second.length()) return 1; else return 0; } } public class Test { static void testArrays(Comparator<Object> cpr){ String[] len = new String[]{"1","22","333","4444","55555"}; Arrays.sort(len,cpr); for (int i=0;i<len.length;i++){ System.out.print(len[i] + " "); } System.out.println(); } public static void main(String[] args){ Comparator<Object> strategyOne = new StrategyOne(); Comparator<Object> strategyTwo = new StrategyTwo(); System.out.println("result of strategy one :"); testArrays(strategyOne); System.out.println("result of strategy two :"); testArrays(strategyTwo); } }
在上面的代码里,Arrays.sort(len,cpr)就是在对策略进行选择,在这个例子里面,有两个策略。Arrays.sort(len,cpr)根据这两个策略来进行排序,排序肯定要进行比较,因此,cpr就定义了这样的比较。它实现了Comarator这个接口的compare()这个方法,这个方法是sort()中会调用的,具体的compare()方法就是具体的策略。
运行结果:
result of strategy one :1 22 333 4444 55555 result of strategy two :55555 4444 333 22 1
关于sort()和compare()方法可以去Google,JAVA中排序就是一个典型的策略模式。