成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

三歪手把手教你干掉if else

開發 前端
今天想來跟大家討論一下怎么干掉if else。已經工作的人可能深有體會:沒有什么是if else搞不掂的,如果有,那就再嵌套一層。

 [[332944]]

本文轉載自微信公眾號「Java3y」,作者Java3y。轉載本文請聯系Java3y公眾號。

今天想來跟大家討論一下怎么干掉if else。

已經工作的人可能深有體會:沒有什么是if else搞不掂的,如果有,那就再嵌套一層。

大多數人都是做業務開發的,if else是避免不了的,但怎么讓if else的邏輯看起來更順眼,變得更加好看,更加好維護呢?

如果之前看過三歪文章的同學可能就會想到「責任鏈模式」。

沒錯就是 責任鏈模式

當你看到一個Service中有一大堆if else 邏輯的時候,可能你會幻想著要不要重構掉,但是始終下不了手。

所以,今天想來分享一個「通用」的責任鏈模式的模板,把if else給套進去就完事了,我相信都能學會。

之前寫設計模式文章的時候,有的同學會評論說我把東西搞復雜了,本來就有簡單的方式去弄,為啥就要嵌套這么多層去搞這些花里胡哨的東西。

在我看來,用最簡單的方式去實現是沒有任何問題的。但達到一定代碼量的時候,多想想一下,換一個人去維護,人家能不能看懂,有沒有更加好的方式,這往往就需要「抽象」的能力。

這也是為什么這么多人推崇設計模式的原因。

不多BB,來吧。

責任鏈通用實現

現在我就默認大家都知道什么是責任鏈模式了,如果還對這個不懂的同學,可以先看看我之前的文章。

 

首先,我們會有一個業務執行器接口,所有的業務實現都會實現該接口,這意味著上圖的邏輯A、B、C都會實現這個接口

  1. /** 
  2.  * 業務執行器 
  3.  * @author 三歪 
  4.  */ 
  5. public interface BusinessProcess { 
  6.     void process(ProcessContext context); 

可以看到的是接口異常的簡單,只有一個process處理的方法,方法接收的是ProcessContext

為什么process方法需要接收ProcessContext?很簡單,我們在處理邏輯A、B、C的時候,可能邏輯B需要依賴邏輯A的處理結果。于是我們就需要有一個載體把這些給記錄下來。

所以,我們就有了ProcessContext,它代表的是責任鏈的上下文。

  1. /** 
  2.  * 責任鏈上下文 
  3.  * @author 3y 
  4.  */ 
  5. public class ProcessContext { 
  6.     // 標識責任鏈的code 
  7.     private String code; 
  8.     // 存儲上下文的真正載體 
  9.     private Model model; 
  10.     // 責任鏈中斷的標識 
  11.     private Boolean needBreak = false

現在責任鏈的執行器和責任鏈所涉及的上下文都已經有了,這意味著我們已經有了責任鏈最主要的抽象了。

接下來就是我們需要把鏈給串起來,于是我們需要一個模板,其實我們做的就是用一個List來把BusinessProcess的子類給串起來。

  1. /** 
  2.  * 業務執行模板(把責任鏈的邏輯串起來) 
  3.  * @author 3y 
  4.  */ 
  5. public class ProcessTemplate { 
  6.     private List<BusinessProcess> processList; 
  7.     public List<BusinessProcess> getProcessList() { 
  8.         return processList; 
  9.     } 
  10.     public void setProcessList(List<BusinessProcess> processList) { 
  11.         this.processList = processList; 
  12.     } 

OK,現在我們已經把責任鏈的整塊給抽象好了,接下來就是暴露流程控制器去執行這個責任鏈:

  1. /** 
  2.  * 責任鏈的流程控制器(整個責任鏈的執行流程通用控制) 
  3.  * @author 3y  
  4.  */ 
  5. @Data 
  6. public class ProcessController { 
  7.      
  8.     // 不同的code 對應不同的責任鏈 
  9.     private Map<String, ProcessTemplate> templateConfig = null
  10.  
  11.     public void process(ProcessContext context) { 
  12.         //根據上下文的Code 執行不同的責任鏈 
  13.         String businessCode = context.getCode(); 
  14.         ProcessTemplate processTemplate = templateConfig.get(businessCode); 
  15.         List<BusinessProcess> actionList = processTemplate.getProcessList(); 
  16.         //遍歷某個責任鏈的流程節點 
  17.         for (BusinessProcess action : actionList) { 
  18.             try { 
  19.                 action.process(context); 
  20.                 if (context.getNeedBreak()) { 
  21.                     break; 
  22.                 } 
  23.             } catch (Exception e2) { 
  24.                 //... 
  25.             } 
  26.         } 
  27.     } 

我們可以看到的是在ProcessController執行鏈通用的流程控制器上會有一個Map去存儲多個責任鏈的模板,這樣做的好處就是:ProcessController這個流程控制器可以根據code支持多個責任鏈執行。

接下來就是我們有具體的BusinessProcess去加入到ProcessTemplate的鏈上,然后調用ProcessController的方法去執行整一條推送鏈。

一般我們在XML注入就好了,比如說現在我們有兩個BusinessProcess的實現,分別是白名單和發消息的邏輯:

  1. /** 
  2.  * 白名單處理器 
  3.  * @author 3y 
  4.  */ 
  5. @Service 
  6. public class WhiteListProcess implements BusinessProcess { 
  7.     @Override 
  8.     public void process(ProcessContext context) { 
  9.         UserModel user = (UserModel) context.getModel(); 
  10.         if ("3y".equals(user.getName())) { 
  11.             context.setNeedBreak(true); 
  12.         } 
  13.     } 
  14.  
  15. /** 
  16.  * 發消息處理器 
  17.  * @author 三歪 
  18.  */ 
  19. @Service 
  20. public class SendMessageProcess implements BusinessProcess { 
  21.  
  22.     @Override 
  23.     public void process(ProcessContext context) { 
  24.         UserModel user = (UserModel) context.getModel(); 
  25.         System.out.println("給"+user.getName()+"發消息"); 
  26.     } 

然后我們把上面兩個處理器添加到ProcessTemplate的模板上,把ProcessTemplate添加到ProcessController的Map上:

  1. <!--發送消息的責任鏈--> 
  2. <bean id="sendMessageTemplate" class="com.chainofresponsibility.ProcessTemplate"
  3.   <property name="processList"
  4.     <list> 
  5.       <ref bean="whiteListProcess"></ref> 
  6.       <ref bean="sendMessageProcess"></ref> 
  7.     </list> 
  8.   </property> 
  9. </bean> 
  10.  
  11. <!--通用流程處理器,維護多條責任鏈--> 
  12. <bean id="processController" class="com.chainofresponsibility.ProcessController"
  13.   <property name="templateConfig"
  14.     <map> 
  15.       <entry key="sendMessage" value-ref="sendMessageTemplate" /> 
  16.     </map> 
  17.   </property> 
  18. </bean> 

然后我們在接口里邊執行這個責任鏈:

  1. @RestController 
  2. public class UserController { 
  3.     @Autowired 
  4.     private ProcessController processController; 
  5.  
  6.     @RequestMapping("/send"
  7.     public void  send(String userName) { 
  8.         // 構建上下文 
  9.         ProcessContext processContext = new ProcessContext(); 
  10.  
  11.         UserModel userModel = new UserModel(); 
  12.         userModel.setAge("24"); 
  13.         userModel.setName(userName); 
  14.         processContext.setModel(userModel); 
  15.  
  16.         processContext.setCode("sendMessage"); 
  17.  
  18.         processController.process(processContext); 
  19.     } 

我做了這么大的一套東西實現了什么功能?其實就一個if邏輯:

  1. if ("3y".equals(userModel.getName())) { 
  2.   return
  3. System.out.println("給" + userModel.getName() + "發消息"); 

下面我們還是來看看效果,從功能上我們可以發現,只要我們輸入的不是「3y」,那就會打印消息

 

上面的邏輯,實際上就是一套通用的責任鏈的代碼,最核心的其實就是四個角色:「業務抽象接口」、「執行過程中的上下文」、「將業務實現類串起來」和「一個通用的控制器執行責任鏈」

 

如果沒看懂的同學,三歪建議再對比一下代碼看看,責任鏈這種設計模式是非常好用,在項目里邊也是非常常見的。

只要把BusinessProcess/ProcessContext/ProcessTemplate/ProcessController的代碼給拷過去自己的項目中,這就能幫你把原有的if else邏輯給干掉。

Pipeline

不知道大家看過Pipeline這個詞了沒,在學Redis的時候可能會見過,在Redis里邊我們會用Pipeline去做批量的操作。

拋開Redis的Pipeline,但從宏觀的角度上來,Pipeline其實是一種架構思想。

同時我也認為它是「責任鏈模式」的實現之一。

下面來看看我這邊的一個Pipeline實現的架構圖:

 

可以看到前人實現的Pipepline還是相對復雜的,沒有上面通用的責任鏈模式好理解,經過分析可以看到都是換湯不換藥的。

下次再見到Pipeline這個詞的時候(因為這個詞還是很常見的),你們就應該能想到責任鏈模式,然后你就發現你看懂了。

代碼GitHub:https://github.com/ZhongFuCheng3y/Java3yTestReposity

 

責任編輯:武曉燕 來源: Java3y
相關推薦

2021-07-14 09:00:00

JavaFX開發應用

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印機

2025-05-07 00:31:30

2023-04-26 12:46:43

DockerSpringKubernetes

2022-01-08 20:04:20

攔截系統調用

2022-03-14 14:47:21

HarmonyOS操作系統鴻蒙

2022-07-27 08:16:22

搜索引擎Lucene

2022-12-07 08:42:35

2011-02-22 13:46:27

微軟SQL.NET

2021-02-26 11:54:38

MyBatis 插件接口

2021-12-28 08:38:26

Linux 中斷喚醒系統Linux 系統

2024-03-05 18:27:43

2024-04-02 08:58:13

2020-08-12 07:41:39

SQL 優化語句

2021-07-01 09:31:50

MySQL SQL 語句數據庫

2017-07-07 11:01:04

Spark性能調優

2023-03-27 08:28:57

spring代碼,starter

2011-04-28 15:09:15

jQueryjqPlot

2010-09-16 14:08:13

無線雙網
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产电影一区二区三区爱妃记 | 久久精品亚洲 | 91av在线免费看 | 一级美国黄色片 | 国产一伦一伦一伦 | 男女午夜免费视频 | 精品99在线 | 国产精品18久久久久久白浆动漫 | 免费a网站| 91中文字幕在线观看 | 亚洲综合在线一区 | 国产一区久久久 | 中文字幕11页 | 国产一区二区三区亚洲 | 在线国产中文字幕 | 日韩第一区 | 污片在线观看 | 欧美三级网站 | 亚洲精品久久久 | 成人激情视频在线播放 | 亚洲视频一区二区三区 | 国产精品一区二区无线 | 亚洲一区二区三区四区五区中文 | 欧美成年视频 | 91精品国产综合久久精品图片 | 日韩手机在线看片 | 欧美日韩1区 | 美女天天干 | 日韩精品一区二区三区 | 999精品视频 | 国产精品久久久久久久久 | 国产精品成人一区二区三区夜夜夜 | 欧州一区二区 | 久久久久久久久综合 | 在线观看h视频 | 性做久久久久久免费观看欧美 | 91精品国产综合久久婷婷香蕉 | 国产成人午夜电影网 | 国产欧美日韩综合精品一区二区 | 国产午夜三级一区二区三 | 精品国产乱码久久久久久影片 |