简述
预先定义有着不同执行过程但结果相同的算法族,运行时指定所需算法。
算法族 此处为一组有共同主题的有相同结果的不同算法的集合。
话不多说,看个优化案例。
优化案例
最初版v0
不使用策略模式的案例。四种不同的计算策略。客户端的代码如下。
// 客户端
public class Client {
public static void main(String[] args) {
String target = "公园";
Scanner sc = new Scanner(System.in);
String input = sc.next();
if ("foot".equals(input)) {
System.out.println("徒步到目的地:" + target);
} else if ("bike".equals(input)) {
System.out.println("骑自行车到目的地:" + target);
} else if ("car".equals(input)) {
System.out.println("开车到目的地:" + target);
}
sc.close();
}
}
具体的条件分支都写在客户端,日后增加新的条件分支时也需要修改客户端。修改客户端这件事往往是不太愿意接受的。原因是我们希望客户端尽可能少的改变,以便减少客