有效的减少代码中太多的ifelse?-策略模式

Posted 0000cjw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有效的减少代码中太多的ifelse?-策略模式相关的知识,希望对你有一定的参考价值。

       写这篇文章的目的和上一篇单例模式一样,策略模式也是一种常用的设计模式,太多的if-else不仅看着不太美观而且不好维护,对于自己来说也等于复习了一遍策略模式。先说一下策略

模式的定义:

       策略模式封装了算法家族,可以让彼此之间互相替换,简单的来说就是比如之前系统调用了两个数据源,现在要添加第三个数据源如果还是使用if-else就需要给所有调用数据源的地方加上

新的判断分支,从而导致维护繁琐。如以下代码:

if(A){
     System.out.println("调用A数据源");
}else if(B){
     System.out.println("调用B数据源");
}

     如果将来随着业务变得复杂,加入C数据源,还要接着加入else if分支,以此类推工作量会越来越繁琐,而且加入了大量冗余代码。。。。

     使用了策略模式之后:只需要在策略类Strategy中定义一个调用所有数据源的公共借口就可以

public abstract class Strategy {

    public abstract void dataInterface();
}

     DataStrategyA,封装了调用A数据源的方法,继承于Strategy

public class DataStrategyA extends Strategy {

    public void dataInterface() {
        System.out.println("调用A数据源");
    }

}

    DataStrategyB,封装了调用B数据源的方法,继承于Strategy

public class DataStrategyB extends Strategy {

    public void dataInterface() {
         System.out.println("调用B数据源");
    }

}

    Context算法调用类,根据具体策略对象调用相应的方法

public class Context {

    private Strategy strategy;
    
    public Context(Strategy strategy) {
        this.strategy = strategy;
    }
    
    public void contextInterface() {
        strategy.dataInterface();
    }
}

     运行效果如下:

public class Test {

    public static void main(String[] args) {
        Context context = new Context(new DataStrategyB());
        context.contextInterface();

    }

}

技术图片

      这样就解决了繁琐的if-else操作了,就算以后加入C、D数据源也只需要增加两个策略类就可以了

      此外,策略模式还有一个优点就是简化了单元测试,每个方法都有自己独立的类,可以通过自己的接口进行单独测试

     当然策略模式也存在着缺点,就是增加了大量的策略类,要求每个开发人员都要了解。策略模式的优点、缺点都说完了怎么样取舍就看大家自己了。不过还是建议大家

使用策略模式。阿里巴巴的java开发手册中也明确表示了if层数超过三层的时候要使用策略模式,

 

 

 

以上是关于有效的减少代码中太多的ifelse?-策略模式的主要内容,如果未能解决你的问题,请参考以下文章

别在再满屏的 ifelse 了,试试策略模式,真香!!

在Spring boot项目中使用策略模式消除if-else

策略模式代替IfElse和SwitchCase

是否有太多的开关盒可以减少圈复杂度?

ios设计模式—策略模式

如何用策略模式,优化你代码里的的if-else?