首页 > 其他分享 >使用工厂模式+策略模式+模板方法实现对大量if...else的改造

使用工厂模式+策略模式+模板方法实现对大量if...else的改造

时间:2023-03-20 10:03:08浏览次数:31  
标签:... return BigDecimal 模式 else Override public 模板

1.策略模式+工厂模式+模板模式

实际开发工程中,一些业务很复杂的逻辑使用很多的 if 或者 if···else 语句,不利于维护和扩展,为了使代码更加优雅,利于维护可以采用策略模式+工厂模式+模板模式设计模式

2.策略模式+工厂模式+模板模式优点

增强了系统的可扩展性。可以根据需要增加新的请求处理类,满足开闭原则。

3.代码实现

业务场景:根据计费方式计算出分润金额和返佣金额

1.定义接口

接口定义抽象方法,继承InitializingBean 的原因是重写afterPropertiesSet方法,将具体实现类注册到工厂类中。

public interface CalHandler extends InitializingBean {
    /**
     * 分润金额计算
     * @return
     */
    BigDecimal calShareAmount();
    /**
     * 返佣金额计算
     * @return
     */
    BigDecimal calCommissionAmount();
}

2.模板类

 * 定义模板类的作用:
 * 1.空实现接口方法,让实现类去实现所需要的抽象方法,否则接口新定义抽象方法,实现类必须实现该方法,不利于扩展
 *   当然也可以使用JDK8默认方法或静态方法将公共的方法放到接口中写,但不推荐
 * 2.公共方法可抽取到抽象类中复用
 *   
 */
public abstract class AbstractCalHandler implements CalHandler{

    @Override
    public BigDecimal calShareAmount() { throw new UnsupportedOperationException(); }

    @Override
    public BigDecimal calCommissionAmount() { throw new UnsupportedOperationException(); }

    public BigDecimal common(){
        System.out.println("调用抽象类公共方法");
        return null;
    }

}

3.定额计算(具体处理者)

@Component
public class FixAmountHandler extends AbstractCalHandler{

    @Override
    public BigDecimal calShareAmount() {
        System.out.println("计算定额逻辑");
        return new BigDecimal("1");
    }

    @Override
    public void afterPropertiesSet() {
        HandlerCalFactory.register("1",this);
    }
}

4.费率计算(具体处理者)

@Component
public class RateAmountHandler extends AbstractCalHandler{
    @Override
    public BigDecimal calShareAmount() {
        System.out.println("计算比例逻辑");
        return new BigDecimal("2");
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        HandlerCalFactory.register("2",this);
    }

}

5.工厂类

public class HandlerCalFactory {
    private static Map<String,CalHandler> map = new HashMap<String,CalHandler>();

    public static void register(String key,CalHandler calHandler){
        if(StringUtils.isEmpty(key) && null == calHandler){
            return;
        }
        map.put(key,calHandler);
    }

    public static CalHandler getInvokeHandler(String key){
        return map.get(key);
    }
    
}

6.测试类

public class Test {
    public static void main(String[] args) {
        CalHandler invokeHandler = HandlerCalFactory.getInvokeHandler("1");
        BigDecimal bigDecimal = invokeHandler.calShareAmount();
    }
}

标签:...,return,BigDecimal,模式,else,Override,public,模板
From: https://www.cnblogs.com/simplejavahome/p/17235281.html

相关文章

  • 前端设计模式——过滤器模式
    前端设计模式中的过滤器模式(FilterPattern)是一种结构型设计模式,它允许我们使用不同的条件来过滤一组对象,并返回符合条件的对象列表。在过滤器模式中,我们有一个包含多个对......
  • 树(更新中....)
    树LinkCutCentroidsProblem-C-Codeforces思路:树的重心,判断一个重心和两个重心的情况。当存在两个重心时,两个重心必相邻。只需把其中一个重心的边连在另一个重心上......
  • 简单明了的体会构建者模式
    我们由一个小小的Demo来引出主题,尽管这个Demo有点长~~,我相信还是值得你一看的!木兰诗中有:“雄兔脚扑朔,雌兔眼迷离;双兔傍地走,安能辨我是雌雄?”对象之间的比较想必大家都很熟......
  • 前端设计模式——原型模式
    原型模式(PrototypePattern):使用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象。在JavaScript中,所有的对象都有一个原型链。原型链是一种机制,它允许我们在对......
  • 设计模式(二十五)----行为型模式之访问者模式
    1概述定义:封装一些作用于某种数据结构中的各元素的操作,它可以在不改变这个数据结构的前提下定义作用于这些元素的新的操作。2结构访问者模式包含以下主要角色:抽......
  • 责任链模式
    begin2021年12月11日20:47:41责任链模式定义Avoidcouplingthesenderofarequesttoitsreceiverbygivingmorethanoneobjectachancetohandlethereque......
  • flutter项目运行时一直卡在Running Gradle task 'assembleDebug'... & Could not reso
    先是看了别人的文章  Flutter项目启动一直卡在RunningGradletask‘assembleDebug‘问题解决-灰信网(软件开发博客聚合)(freesion.com),做了同样的处理,但接着又报错......
  • java设计模式 之 单例模式
    单例模式单例模式(SingletonPattern)是Java中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。对于整个软件系统中,对于某个......
  • 代理模式
    1静态代理2什么是动态代理?动态代理是通过创建代理对象,在不改变原有代码的基础上,给程序增加新的功能,实现了程序的功能增强3动态代理有哪些JDK动态代理CGLB动态......
  • 【设计模式】责任链3-横刀植入
    紧接着上一篇的开始:我们来说说普遍的解决方案,我们用一个类来模拟:这个类模拟一个够过滤器链条:packagecn.edu.hpu.responsibility;importjava.ut......