文章目录
适用的场景
1、如果在一个系统里面有许多类,它们之间的区别仅在于它们的行为,那么使用策略模式可以动态地让一个对象在许多行为中选择一种行为。
2、一个系统需要动态地在几种算法中选择一种。
3、如果一个对象有很多的行为,如果不用恰当的模式,这些行为就只好使用多重的条件选择语句来实现。
实际列子:
jdk中的 Comparator 里面的int compare(T o1, T o2)方法
举列:
抱歉 sort 方法里面的参数应该是类数组我的抱歉没改
比如 一个猫(类)属性有(体重 身高)
问题一 猫按体重排序:
我们来个类 把这些方法 写进来:
问题2:我要拓展 狗也可以按照体重排序
现然 这个就要引入泛型:
问题 我再拓展 猫按照身高排序,狗按照年龄:
此时 你可能想到要 在method里面再来个方法 sortheight即可
但是 这样 需要进行修改代码 违背了开闭原则:即拓展开放修改关闭
此时引入 策略模式:
你就可以 按你的想法进行创建类 然后再去自定义比较的方法。
调用:
总结:
优点: 显而易见高类聚低耦合
就拿我的列子说明 你要是想改变排序方法只需要建类即可