简述:
在软件开发中常常遇到这种情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法或者策略来完成该功能。如查找、排序等,一种常用的方法是硬编码(Hard Coding)在一个类中,如需要提供多种查找算法,可以将这些算法写到一个类中,在该类中提供多个方法,每一个方法对应一个具体的查找算法;当然也可以将这些查找算法封装在一个统一的方法中,通过if…else…或者case等条件判断语句来进行选择。
这两种实现方法我们都可以称之为硬编码,如果需要增加一种新的查找算法,需要修改封装算法类的源代码;更换查找算法,也需要修改客户端调用代码。在这个算法类中封装了大量查找算法,该类代码将较复杂,维护较为困难。如果我们将这些策略包含在客户端,这种做法更不可取,将导致客户端程序庞大而且难以维护,如果存在大量可供选择的算法时问题将变得更加严重。
把一个类中经常改变或者将来可能改变的部分提取出来,作为一个接口,然后在类中包含这个对象的实例,这样类的实例在运行时就可以随意调用实现了这个接口的类的行为。
比如定义一系列的算法,把每一个算法封装起来, 并且使它们可相互替换,使得算法可独立于使用它的客户而变化。这就是策略模式。
优缺点
优点:
1、可以动态的改变对象的行为
缺点:
1、客户端必须知道所有的策略类,并自行决定使用哪一个策略类
2、策略模式将造成产生很多策略类
实现思路
1.策略的抽象(规定子类的操作而不做具体操作)
2.实现或者继承抽象类做具体的操作
3.操作策略的类
实现代码
小明某一天到了怡红院开始选择他的女神 这个选择的过程就可以称之为一个策略
1.策略的抽象:
interface IStrategy {
fun operate()
}
2.具体的实现策略类
//策略一
class StrategyOne :IStrategy{
override fun operate() {
println("小*玛利亚")
}
}
//策略二
class StrategyTwo :IStrategy{
override fun operate() {
println("苍井*")
}
}
//策略三
class StrategyThree :IStrategy{
override fun operate() {
println("波多野结*")
}
}
3.操作策略的类
//怡红院
class YihongGarden(iStrategy: IStrategy) {
val iStrategy = iStrategy
fun operate() {
iStrategy.operate()
}
}
4.执行看结果
fun main(args: Array<String>) {
val one = YihongGarden(StrategyOne())
one.operate()
val two = YihongGarden(StrategyTwo())
two.operate()
val three = YihongGarden(StrategyThree())
three.operate()
}
image.png
当然你可以用这种方法实现
fun main(args: Array<String>) {
operate(1)
operate(2)
operate(3)
}
fun operate(strategy:Int) {
when(strategy){
1-> println("小*玛利亚")
2-> println("苍井*")
3-> println("波多野结*")
}
}
可是你要知道这只是一个Demo每个逻辑里面代码只有一行可是你项目里面肯定不只一行吧
这种方法用到你项目里可能会造成可读性很差、代码特别臃肿、难以维护
网友评论