在原有代码基础上,如何一步步通过设计模式去优化代码?日常工作中,我们用得最多的设计模式,就是策略模式、工厂模式和模板方法模式啦。
成都创新互联公司是专业的番禺网站建设公司,番禺接单;提供成都网站制作、做网站、外贸营销网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行番禺网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
大家先看下,优化前,原有代码的大概逻辑哈。代码如下:
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 Mapmap = new ConcurrentHashMap<>();
//策略实现类注入到map
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
MaptempMap = applicationContext.getBeansOfType(IGroupLabelStrategyService.class);
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);
}
}
策略模式、工厂模式和模板方法模式这三种设计模式,是日常开发用得最多的。本文呢,也是阐述了我是如何在原有代码上,抽取出设计模式的,大家可以应用到自己的工作中去哈。
文章标题:干掉ifelse!试试这三种设计模式,优化代码贼顺手!
当前路径:http://www.gawzjz.com/qtweb/news23/200173.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联