0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

設(shè)計模式之責任鏈模式概述

jf_xutpKvFS ? 來源:老漢聊技術(shù) ? 2023-09-27 09:54 ? 次閱讀

概述

設(shè)計模式是一些被反復(fù)使用的、具有普遍性的設(shè)計解決方案,它們是在特定情境下對軟件設(shè)計問題的成功解決方式的總結(jié)和歸納。常見的設(shè)計模式可以分為以下三類:

創(chuàng)建型模式:這些模式用于處理對象的創(chuàng)建過程,包括工廠模式、抽象工廠模式、單例模式、建造者模式和原型模式。

結(jié)構(gòu)型模式:這些模式用于處理對象之間的組合,包括適配器模式、橋接模式、組合模式、裝飾模式、外觀模式、享元模式和代理模式。

行為型模式:這些模式用于處理對象之間的交互,包括責任鏈模式、命令模式、解釋器模式、迭代器模式、中介者模式、備忘錄模式、觀察者模式、狀態(tài)模式、策略模式、模板方法模式和訪問者模式。

這些設(shè)計模式提供了在軟件設(shè)計中常用的一些解決方案,幫助開發(fā)人員更加高效地進行設(shè)計和開發(fā)。同時,這些模式還提高了代碼的可維護性和可擴展性。

責任鏈模式

責任鏈模式(Chain of Responsibility Pattern)是一種行為型設(shè)計模式,它可以將請求的發(fā)送者和接收者解耦,并且使得多個對象都有機會處理請求,從而避免了請求的發(fā)送者和接收者之間的耦合關(guān)系。責任鏈模式通常被用來處理復(fù)雜的請求處理流程,例如在一個大型系統(tǒng)中,一個請求可能需要經(jīng)過多個處理器才能最終被處理。

一、應(yīng)用場景

責任鏈模式通常適用于以下情況:

當有多個對象可以處理一個請求,并且它們需要按照一定的順序處理請求時,可以使用責任鏈模式。

當需要動態(tài)地添加或刪除請求處理對象時,可以使用責任鏈模式。

當需要將請求處理對象從主體中分離出來時,可以使用責任鏈模式。

典型應(yīng)用場景如下:

Web 應(yīng)用程序中的過濾器:Web 應(yīng)用程序中經(jīng)常使用過濾器,來對請求進行預(yù)處理或后處理。使用責任鏈模式可以動態(tài)地將過濾器添加到鏈中,從而實現(xiàn)對請求的預(yù)處理或后處理。

日志記錄:日志記錄是一種典型的責任鏈模式。在日志記錄中,日志記錄器通常會根據(jù)日志級別將日志分成不同的等級,并將日志發(fā)送到相應(yīng)的處理器進行處理。

異常處理:在程序中,可能會發(fā)生各種異常情況,如空指針異常、數(shù)組越界異常等。使用責任鏈模式可以將不同類型的異常處理器組成一個鏈,從而依次處理異常,并在鏈的末尾將異常記錄到日志中。

消息處理:在消息隊列中,可能會有多個消息處理器,用于處理不同類型的消息。使用責任鏈模式可以將這些消息處理器組成一個鏈,從而依次處理消息,并將消息傳遞給下一個處理器。

二、實現(xiàn)方式

責任鏈模式通常由以下角色組成:

抽象處理器(Handler):定義了一個處理請求的接口,并且保持了一個對下一個處理器的引用。

具體處理器(ConcreteHandler):實現(xiàn)了抽象處理器的接口,處理請求的同時,也能夠決定是否將請求轉(zhuǎn)發(fā)給下一個處理器。

客戶端(Client):創(chuàng)建責任鏈,并將請求發(fā)送給第一個處理器。

三、代碼示例

下面是一個使用責任鏈模式的示例,假設(shè)有一個業(yè)務(wù)流程,需要依次經(jīng)過三個處理器才能完成。如果某個處理器無法處理請求,它將請求轉(zhuǎn)發(fā)給下一個處理器,直到請求被處理完成。

wKgZomUTi82ACqPNAAEZAomBLos665.jpg
wKgaomUTi9uAT6L-AADxaw1qOYI296.jpg

上述示例中,Handler 是抽象處理器,定義了處理請求的接口,并保持了一個對下一個處理器的引用。ConcreteHandler1、ConcreteHandler2 和 ConcreteHandler3 是具體處理器,實現(xiàn)了抽象處理器的接口,并能夠處理請求,并決定是否將請求轉(zhuǎn)發(fā)給下一個處理器。Client是客戶端,創(chuàng)建了責任鏈,并將請求發(fā)送給第一個處理器。

運行該示例,將會輸出如下內(nèi)容:

ConcreteHandler1 is handling the request.ConcreteHandler2 is handling the request.ConcreteHandler3 is handling the request.No handler is available.

四、優(yōu)缺點

優(yōu)點:

可以將請求的發(fā)送者和接收者解耦,并且使得多個對象都有機會處理請求,從而避免了請求的發(fā)送者和接收者之間的耦合關(guān)系。

可以動態(tài)地添加或刪除請求處理對象,從而增加或減少請求處理的靈活性。

可以將請求處理對象從主體中分離出來,從而簡化了主體的代碼。

缺點:

如果責任鏈太長,可能會導(dǎo)致請求的處理時間過長,從而影響系統(tǒng)性能。

如果責任鏈的配置不當,可能會導(dǎo)致請求不能被正確處理。

五、總結(jié)

責任鏈模式是一種行為型設(shè)計模式,它可以將請求的發(fā)送者和接收者解耦,并且使得多個對象都有機會處理請求。責任鏈模式適用于多個對象可以處理一個請求,并且需要按照一定的順序處理請求的情況。使用責任鏈模式可以動態(tài)地添加或刪除請求處理對象,從而增加或減少請求處理的靈活性,但如果責任鏈太長,可能會導(dǎo)致請求的處理時間過長,從而影響系統(tǒng)性能。







審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19100

    瀏覽量

    228814
  • 接收機
    +關(guān)注

    關(guān)注

    8

    文章

    1177

    瀏覽量

    53377
  • 過濾器
    +關(guān)注

    關(guān)注

    1

    文章

    427

    瀏覽量

    19520
  • 迭代器
    +關(guān)注

    關(guān)注

    0

    文章

    43

    瀏覽量

    4296

原文標題:設(shè)計模式之責任鏈模式

文章出處:【微信號:LabVIEW QT 修煉之路,微信公眾號:LabVIEW QT 修煉之路】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    CKS32F4xx系列MCU的低功耗模式睡眠模式

    本課講為大家講解CKS32F4xx系列產(chǎn)品的低功耗模式睡眠(Sleep)模式。MCU為滿足某些應(yīng)用場景:如小型化低容量設(shè)備,長期監(jiān)測設(shè)備等,低功耗應(yīng)運而生,其中根據(jù)需求,用戶可以選擇睡眠模式
    發(fā)表于 06-26 10:02 ?613次閱讀
    CKS32F4xx系列MCU的低功耗<b class='flag-5'>模式</b><b class='flag-5'>之</b>睡眠<b class='flag-5'>模式</b>

    電機控制常用算法概述(3)

    和驅(qū)動順序是不變的。未完待續(xù)?。”疚南嚓P(guān)文章1? 電機控制常用算法概述(1)2?電機控制常用算法概述(2)
    發(fā)表于 10-29 16:45

    什么是設(shè)計模式?為什么要學習設(shè)計模式

    物是人非事事休,當周圍的一切都發(fā)生著改變,包括我們的需求、程序等,我們又該如何去應(yīng)對和解決呢?歡迎進入編程人員必經(jīng)之路------設(shè)計模式1 本篇概述什么是設(shè)計模式為什么要學習設(shè)計模式
    發(fā)表于 01-19 06:41

    什么是菊花模式 星型模式

    什么是菊花模式 星型模式 菊花模式   菊花
    發(fā)表于 12-05 09:00 ?8488次閱讀

    Modbus ASCII 模式通訊程序

    C語言編寫的臺達變頻器Modbus ASCII 模式通訊程序
    發(fā)表于 12-02 10:25 ?6次下載

    概述STM32中GPIO的8種工作模式

    概述STM32中GPIO的8種工作模式
    發(fā)表于 07-06 17:35 ?26次下載
    <b class='flag-5'>概述</b>STM32中GPIO的8種工作<b class='flag-5'>模式</b>

    C語言設(shè)計模式的程序資料合集

    模板模式,C語言設(shè)計模式工廠模式,C語言設(shè)計模式
    發(fā)表于 11-16 08:00 ?4次下載

    嵌入式軟件設(shè)計設(shè)計模式

    文章目錄前言1.設(shè)計模式適配器模式2.設(shè)計模式單例模式3.設(shè)計
    發(fā)表于 10-21 11:07 ?9次下載
    嵌入式軟件設(shè)計<b class='flag-5'>之</b>設(shè)計<b class='flag-5'>模式</b>

    STM32低功耗模式待機模式

    上周完成了一個小項目,項目涉及到stm32的低功耗的待機模式,特在此記錄下32的待機模式。 芯片:STM32f030F4 庫:HAL庫 喚醒方式:用RTC和PA0的上升沿喚醒先來看下低功耗模式
    發(fā)表于 12-07 16:21 ?8次下載
    STM32低功耗<b class='flag-5'>模式</b><b class='flag-5'>之</b>待機<b class='flag-5'>模式</b>

    一起看看責任設(shè)計模式吧!

    如何解決這個問題,我們可以通過鏈表將每一關(guān)連接起來,形成責任的方式,第一關(guān)通過后是第二關(guān),第二關(guān)通過后是第三關(guān) ....,這樣客戶端就不需要進行多重 if 的判斷了
    的頭像 發(fā)表于 07-08 16:25 ?827次閱讀

    什么是責任?

    責任模式是行為模式的一種,它將需要觸發(fā)的Handler組成一條,發(fā)送者將請求發(fā)給的第一個接
    的頭像 發(fā)表于 02-16 14:41 ?884次閱讀

    如何用責任默認優(yōu)雅地進行參數(shù)校驗

    那么有什么更好的參數(shù)校驗的方式呢?本文就推薦一種通過責任設(shè)計模式來優(yōu)雅地實現(xiàn)參數(shù)的校驗功能,我們通過一個用戶注冊的例子來講明白如何實現(xiàn)。
    的頭像 發(fā)表于 04-06 15:00 ?435次閱讀

    責任設(shè)計模式詳解

    責任模式是一種行為設(shè)計模式, 允許你將請求沿著處理者進行發(fā)送。收到請求后, 每個處理者均可對請求進行處理, 或?qū)⑵鋫鬟f給
    的頭像 發(fā)表于 05-22 15:12 ?409次閱讀
    <b class='flag-5'>責任</b><b class='flag-5'>鏈</b>設(shè)計<b class='flag-5'>模式</b>詳解

    內(nèi)部補償高級電流模式(ACM)概述

    電子發(fā)燒友網(wǎng)站提供《內(nèi)部補償高級電流模式(ACM)概述.pdf》資料免費下載
    發(fā)表于 08-26 14:55 ?1次下載
    內(nèi)部補償高級電流<b class='flag-5'>模式</b>(ACM)<b class='flag-5'>概述</b>

    還在自己實現(xiàn)責任?我建議你造輪子之前先看看這個開源項目

    1. 前言 設(shè)計模式在軟件開發(fā)中被廣泛使用。通過使用設(shè)計模式,開發(fā)人員可以更加高效地開發(fā)出高質(zhì)量的軟件系統(tǒng),提高代碼的可讀性、可維護性和可擴展性。 責任
    的頭像 發(fā)表于 09-20 14:38 ?280次閱讀
    還在自己實現(xiàn)<b class='flag-5'>責任</b><b class='flag-5'>鏈</b>?我建議你造輪子之前先看看這個開源項目