日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java描述设计模式(15):责任链模式

發布時間:2025/3/17 java 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java描述设计模式(15):责任链模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文源碼:GitHub·點這里 || GitEE·點這里

一、生活場景描述

1、請假審批流程

公司常見的請假審批流程:請假天數

當 day<=3 天,項目經理審批 當 3<day<=5 天,部門經理審批 當 day>5 天,CEO審批

2、流程圖解

3、代碼實現

public class C01_InScene {public static void main(String[] args) {// 組裝責任鏈AuditHandler h1 = new CeoManger();AuditHandler h2 = new DeptManger();AuditHandler h3 = new ProjectManger();h3.setSuccessor(h2);h2.setSuccessor(h1);/** 測試輸出* 項目經理無權審批* 部門經理無權審批* CEO審批:同意【Cicada】,請假【6】天*/h3.handleLeaveDay("Cicada",6);} } abstract class AuditHandler {//持有下一個處理請求的對象protected AuditHandler successor = null;public AuditHandler getSuccessor() {return successor;}public void setSuccessor(AuditHandler successor) {this.successor = successor;}public abstract void handleLeaveDay (String user,Integer day); }/*** 項目經理審批*/ class ProjectManger extends AuditHandler{@Overridepublic void handleLeaveDay(String user, Integer day) {if (day <= 3){System.out.println("項目經理審批:同意【"+user+"】,請假【"+day+"】天");} else {System.out.println("項目經理無權審批");if (getSuccessor() != null){getSuccessor().handleLeaveDay(user,day);}}} } /*** 部門經理審批*/ class DeptManger extends AuditHandler{@Overridepublic void handleLeaveDay(String user, Integer day) {if (day > 3 && day <= 5){System.out.println("部門經理審批:同意【"+user+"】,請假【"+day+"】天");} else {System.out.println("部門經理無權審批");if (getSuccessor() != null){getSuccessor().handleLeaveDay(user,day);}}} } /*** CEO審批*/ class CeoManger extends AuditHandler{@Overridepublic void handleLeaveDay(String user, Integer day) {if (day > 5){System.out.println("CEO審批:同意【"+user+"】,請假【"+day+"】天");} else {if (getSuccessor() != null){getSuccessor().handleLeaveDay(user,day);}}} }

二、責任鏈模式

1、基礎概念

責任鏈模式是一種對象的行為模式。在責任鏈模式里,很多對象由每一個對象對其下個的引用而連接起來形成一條鏈式結構。請求在這個鏈上傳遞,直到鏈上的某一個對象有權處理該請求。請求的客戶端不知道鏈上的哪個對象處理該請求,這使得系統可以在不影響客戶端的情況下動態地重新組織和分配責任對象。

2、核心角色

(1)、抽象處理者角色

定義處理請求的接口。接口可以也可以給出一個方法以設定和返回對下個對象引用。這個角色通常由一個Java抽象類或者Java接口實現。

(2)、具體處理者角色

具體處理者接到請求后,可以選擇將請求處理掉,或者將請求傳給下個對象。由于具體處理者持有對下家的引用。

3、模式圖解

4、源代碼實現

public class C02_Chain {public static void main(String[] args) {// 組裝責任鏈Handler handler1 = new ConcreteHandler();Handler handler2 = new ConcreteHandler();handler1.setHandler(handler2);// 提交請求handler1.handlerRequest();} } /*** 抽象處理者角色*/ abstract class Handler {/** 持有后續的責任對象*/protected Handler handler;/*** 處理請求的方法*/public abstract void handlerRequest();public Handler getHandler() {return handler;}public void setHandler(Handler handler) {this.handler = handler;} } /*** 具體處理者角色*/ class ConcreteHandler extends Handler{/*** 調用該方法處理請求*/@Overridepublic void handlerRequest() {/** 判斷是否有后續的責任對象,沒有就出來請求,有就直接放過*/if(getHandler() != null){System.out.println("放過請求,下個對象處理...");getHandler().handlerRequest();} else{System.out.println("直接處理請求了...");}} }

三、Spring框架應用

1、DispatcherServlet類的

DispatcherServlet 核心方法 doDispatch。HandlerExecutionChain只是維護HandlerInterceptor的集合,可以向其中注冊相應的攔截器,本身不直接處理請求,將請求分配給責任鏈上注冊處理器執行,降低職責鏈本身與處理邏輯之間的耦合程度。

HandlerExecutionChain mappedHandler = null; mappedHandler = this.getHandler(processedRequest); mappedHandler.applyPreHandle(processedRequest, response); mappedHandler.applyPostHandle(processedRequest, response, mv);

2、HandlerExecutionChain類

這里分析的幾個方法,都是從DispatcherServlet類的doDispatch方法中請求的。

  • 獲取攔截器,執行preHandle方法。
boolean applyPreHandle(HttpServletRequest request, HttpServletResponse response) throws Exception {HandlerInterceptor[] interceptors = this.getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for(int i = 0; i < interceptors.length; this.interceptorIndex = i++) {HandlerInterceptor interceptor = interceptors[i];if (!interceptor.preHandle(request, response, this.handler)) {this.triggerAfterCompletion(request, response, (Exception)null);return false;}}}return true; }
  • 在applyPreHandle方法中,執行triggerAfterCompletion方法。
void triggerAfterCompletion(HttpServletRequest request, HttpServletResponse response, Exception ex) throws Exception {HandlerInterceptor[] interceptors = this.getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for(int i = this.interceptorIndex; i >= 0; --i) {HandlerInterceptor interceptor = interceptors[i];try {interceptor.afterCompletion(request, response, this.handler, ex);} catch (Throwable var8) {logger.error("HandlerInterceptor.afterCompletion threw exception", var8);}}} }
  • 獲取攔截器,執行applyPostHandle方法。
void applyPostHandle(HttpServletRequest request, HttpServletResponse response, ModelAndView mv) throws Exception {HandlerInterceptor[] interceptors = this.getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for(int i = interceptors.length - 1; i >= 0; --i) {HandlerInterceptor interceptor = interceptors[i];interceptor.postHandle(request, response, this.handler, mv);}} }

四、模式總結

  • 將請求和處理邏輯分開,實現解耦提高系統的靈活性;
  • 當責任鏈過長時,性能會下降,測試也會變得復雜;
  • 應用場景:請假、加薪、費用等常見的審批流程;
  • 五、源代碼地址

    GitHub·地址 https://github.com/cicadasmile/model-arithmetic-parent GitEE·地址 https://gitee.com/cicadasmile/model-arithmetic-parent

    新人創作打卡挑戰賽發博客就能抽獎!定制產品紅包拿不停!

    總結

    以上是生活随笔為你收集整理的Java描述设计模式(15):责任链模式的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。