在原有代码基础上,干掉如何一步步通过设计模式去优化代码?试试式优顺手日常工作中,我们用得最多的种设设计模式,就是计模策略模式、工厂模式和模板方法模式啦。化代 大家先看下,干掉优化前,试试式优顺手原有代码的种设大概逻辑哈。代码如下: class Parameter{ int pageSize; int pageNo; int reqNum; //其他参数。计模 } //逻辑处理,化代是码贼否命中客群 boolean isMarketHit(Parameter dto){ //如果是企业客群类型 if(dto.type == enterprise){ //开关关闭不请求 if(isEnterpriseSwitchClose){ return false; } //请求只有一条记录的话 if(dto.reqNum==1){ //调用大数据的点查接口 return singleRemoteEOIinvoke(dto); //请求超过一条的话 }else if(dto.reqNum>1){ //调用大数据的批量接口 return batchRemoteEOIinvoke(dto); } //如果是市场营销类型 }else if(dto.type==market_list){ //开关关闭不请求 if(isMarketListSwitchClose){ return false; } //请求只有一条记录的话 if(dto.reqNum==1){ //调用营销的点查接口 return singleRemoteMarketinvoke(dto); //请求超过一条的话 }else if(dto.reqNum>1){ //调用营销的批量接口 return batchRemoteMarketinvoke(dto); } } 这个代码可能存在哪些问题呢? 说得专业一点点,试试式优顺手就是种设以上代码,违背了面向对象的开闭原则和单一原则。 回忆一下,什么是策略模式呢? 策略模式定义了算法族,分别封装起来,亿华云让它们之间可以相互替换,此模式让算法的变化独立于使用算法的的客户。这个策略模式的定义是不是有点抽象呢?打个通俗易懂的比喻: 策略模式针对一组算法,将每一个算法封装到实现共同接口的不同独立的类中,站群服务器从而使得它们可以相互替换。策略模式我们一般是怎么定义的呢? 所以,对于原有的伪代码流程,我们就可以定义企业客群类型的策略实现类,和市场营销类型的策略实现类。这两个策略实现类都实现了两个方法,一个方法是匹配类型的,就是返回原始代码if...else条件判断的类型;然后另外个方法,就是if...else条件的实现内容。代码如下: //一个接口 interface IGroupLabelStrategyService { //这个方法对应策略实现类的具体实现 boolean processBiz(Parameter dto); //这个方法就是策略类的类型,也就是对应```if...else```条件判断的类型 String getType(); } //企业客群类型的策略实现类 EnterpriseGroupLablelStrategyServiceImpl implements IGroupLabelStrategyService{ //对应企业客群类型的条件分支里面的实现 boolean processBiz(Parameter dto){ //开关关闭不请求 if(isEnterpriseSwitchClose){ return false; } //请求只有一条记录的话 if(dto.reqNum==1){ //调用大数据的点查接口 return singleRemoteEOIinvoke(dto); //请求超过一条的话 }else if(dto.reqNum>1){ //调用远程大数据批量接口 return batchRemoteEOIinvoke(dto); } } //对应企业类型 String getType(){ return "enterprise"; } } //市场营销类型的策略实现类 MarketListGroupLablelStrategyServiceImpl implements IGroupLabelStrategyService{ //对应市场营销类型的条件分支里面的实现 boolean processBiz(Parameter dto){ //开关关闭不请求 if(isMarketListSwitchClose){ return false; } //请求只有一条记录的话 if(dto.reqNum==1){ //调用营销点查接口 return singleRemoteMarketinvoke(dto); //请求超过一条的话 }else if(dto.reqNum>1){ //调用营销批量接口 return batchRemoteMarketinvoke(dto); } } String getType(){ return "market_list"; } 每个策略现在都实现好了,不同策略的实现类怎么交给spring管理呢? 我们可以实现ApplicationContextAware接口,把策略的实现类注入到一个map,然后根据请求方不同的策略请求类型,去实现不同的调用嘛,其实就是类似于工厂模式的思想啦。代码如下: @Component public class GroupLabelStrategyServiceFactory implements ApplicationContextAware{ //存放对应的类型和实现类 private Map //策略实现类注入到map @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { Map tmepMap.values().forEach(strategyService -> map.put(strategyService.getType(), strategyService)); } //工厂方法 public boolean processBiz(ParamDTO dto){ //根据不同类型,获取不同的实现类 IGroupLabelStrategyService groupLabelStrategyService= map.get(dto.getType()); if (batchGroupLabelJudgeService != null) { return groupLabelStrategyService.processBiz(dto); } return false; } 有了策略模式+工厂方法模式后,我们伪代码流程简化成这样啦: class Parameter{ int pageSize; int pageNo; int reqNum; //其他参数。 } boolean isMarketHit(Parameter dto){ //直接调用工厂类就可以啦,其他逻辑处理已经在策略实现类里面了。 return groupLabelStrategyServiceFactory.processBiz(dto); 小伙伴们,细心回头观察下原先的伪代码流程,会发现一个共性的代码流程,就是先开关控制,然后根据请求数量决定走单笔调用还是批量调用。 这就可以使用模板方法继续优化了。所谓模板方法模式,其实就是: 为了通俗易懂一点,打个比喻: 模板方法使用比较简单: 我们只需要把开关控制接口,单笔远程调用、批量远程调用这个通用共性的流程,定义到模板抽象类就好啦。代码如下: public abstract AbstractGroupLabelJudgeTemplate implements IGroupLabelStrategyService{ //模板骨架 public boolean processBiz(Parameter dto){ if(isSwitchClose){ return false; } if(dto.reqNum==1){ return singleRemote(dto); }else if(dto.reqNum>1){ return batchRemote(dto); } } //开关由子类控制 abstract boolean isSwitchClose(); //单笔远程调用,由子类控制 astract boolean singleRemote(dto); //批量远程调用,由子类控制 astract boolean batchRemote(dto); 不同的策略子类自己控制开关,和控制不同接口的调用即可。 EnterpriseGroupLablelStrategyServiceImpl extends AbstractGroupLabelJudgeTemplate{ boolean isSwitchClose(){ //企业客群开关 } boolean singleRemote(ParamDTO dto){ //企业客群单笔调用 return singleRemoteEOIinvoke(dto); } boolean batchRemote(ParamDTO dto){ //企业客群批量调用 return batchRemoteEOIinvoke(dto); } } MarketListGroupLablelStrategyServiceImpl extends AbstractGroupLabelJudgeTemplate{ boolean isSwitchClose(){ //营销客群开关 } boolean singleRemote(ParamDTO dto){ //营销客群单笔调用 return singleRemoteMarketinvoke(dto); } boolean batchRemote(ParamDTO dto){ //营销客群批量调用 return batchRemoteMarketinvoke(dto); } 策略模式、工厂模式和模板方法模式这三种设计模式,是日常开发用得最多的。本文呢,也是阐述了我是如何在原有代码上,抽取出设计模式的,大家可以应用到自己的工作中去哈。前言
1. 优化前伪代码流程
2. 策略模式是如何应用进去的
大家是否还记得,如果代码中有多个if...else等条件分支,并且每个条件分支,可以封装起来替换的,我们就可以使用策略模式来优化。3. 工厂设计模式是怎么使用的
4. 模板方法模式又是怎么应用进去的
5. 唠叨几句
上一篇
下一篇