Java 設計模式之責任鏈模式及異步責任鏈詳解
一、定義
責任鏈模式(Chain of Responsibility Pattern):避免將一個請求的發(fā)送者與接受者耦合在一起,讓多個對象都有機會處理請求。將接受請求的對象連接成一條鏈,并且沿著這條鏈傳遞請求,直到有一個對象能夠處理它為止。
在很多源碼都有涉及,如Mybatis攔截器、Filter…

責任鏈模式屬于行為型模式。
二、普通責任鏈模式

抽象處理類:AbstractProcessor
/**
* 抽象處理類
*/
public abstract class AbstractProcessor {
// 責任鏈
private AbstractProcessor nextProcessor;
public void setNextProcessor(AbstractProcessor nextProcessor){
this.nextProcessor = nextProcessor;
}
/**
* 鏈路調(diào)用
* @param obj
*/
public void execute(Object obj) {
this.processor(obj);
if (this.nextProcessor != null){
this.nextProcessor.execute(obj);
}
}
public abstract void processor(Object obj);
}
具體類:ParamsProcessor、CheckProcessor、FinalProcessor
public class ParamsProcessor extends AbstractProcessor{
@Override
public void processor(Object obj) {
System.out.println("paramsProcessor>>>>>>>>>>" + obj.toString());
}
}
public class CheckProcessor extends AbstractProcessor{
@Override
public void processor(Object obj) {
System.out.println("checkProcessor>>>>>>>>>>" + obj.toString());
}
}
public class FinalProcessor extends AbstractProcessor{
@Override
public void processor(Object obj) {
System.out.println("finalProcessor>>>>>>>>>>" + obj.toString());
}
}
測試類:ProcessorMainTest
public class ProcessorMainTest {
public static void main(String[] args) {
/**
* 構(gòu)建一個鏈路
* paramsProcessor -> checkProcessor -> finalProcessor
*/
AbstractProcessor paramsProcessor = new ParamsProcessor();
AbstractProcessor checkProcessor = new CheckProcessor();
AbstractProcessor finalProcessor = new FinalProcessor();
paramsProcessor.setNextProcessor(checkProcessor);
checkProcessor.setNextProcessor(finalProcessor);
paramsProcessor.execute("Java責任鏈模式");
}
}
執(zhí)行結(jié)果
paramsProcessor>>>>>>>>>>Java責任鏈模式
checkProcessor>>>>>>>>>>Java責任鏈模式
finalProcessor>>>>>>>>>>Java責任鏈模式
三、異步責任鏈模式
異步責任鏈模式采用責任鏈模式、生產(chǎn)者消費者模式組合。

抽象處理類:AbstractAsynProcessor
/**
* 異步責任鏈:采用線程、生產(chǎn)者消費者模式實現(xiàn)
*/
public abstract class AbstractAsynProcessor extends Thread {
// 用于存放當前責任鏈需要處理的對象
protected BlockingQueue<Object> queue;
// 鏈路對象
private AbstractAsynProcessor nextProcessor;
/**
* 執(zhí)行
*
* @param obj
*/
public void execute(Object obj) throws InterruptedException {
this.processor(obj);
if (this.nextProcessor != null) {
this.nextProcessor.getQueue().put(obj);
}
}
@Override
public void run() {
// 執(zhí)行
try {
while (true) {
// 生產(chǎn)者消費者
Object obj = this.queue.take();
execute(obj);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public abstract void processor(Object obj);
public BlockingQueue<Object> getQueue() {
return queue;
}
public void setNextProcessor(AbstractAsynProcessor nextProcessor) {
this.nextProcessor = nextProcessor;
}
}
具體類:AsynParamsProcessor、AsynCheckProcessor、AsynFinalProcessor
public class AsynParamsProcessor extends AbstractAsynProcessor {
public AsynParamsProcessor() {
// 初始化隊列
this.queue = new LinkedBlockingQueue<>();
}
@Override
public void processor(Object obj) {
System.out.println("asynParamsProcessor>>>>>>>>>>" + obj.toString());
}
}
public class AsynCheckProcessor extends AbstractAsynProcessor {
public AsynCheckProcessor(){
this.queue = new LinkedBlockingQueue<>();
}
@Override
public void processor(Object obj) {
System.out.println("asynCheckProcessor>>>>>>>>>>" + obj.toString());
}
}
public class AsynFinalProcessor extends AbstractAsynProcessor {
public AsynFinalProcessor() {
this.queue = new LinkedBlockingQueue<>();
}
@Override
public void processor(Object obj) {
System.out.println("asynFinalProcessor>>>>>>>>>>" + obj.toString());
}
}
測試類:AsynProcessorMainTest
public class AsynProcessorMainTest {
public static void main(String[] args) throws InterruptedException {
/**
* 構(gòu)建一個鏈路
* asynParamsProcessor -> asynCheckProcessor -> asynFinalProcessor
*/
AbstractAsynProcessor asynParamsProcessor = new AsynParamsProcessor();
asynParamsProcessor.start();
AbstractAsynProcessor asynCheckProcessor = new AsynCheckProcessor();
asynCheckProcessor.start();
AbstractAsynProcessor asynFinalProcessor = new AsynFinalProcessor();
asynFinalProcessor.start();
asynParamsProcessor.setNextProcessor(asynCheckProcessor);
asynCheckProcessor.setNextProcessor(asynFinalProcessor);
Scanner input = new Scanner(System.in);
while (true) {
Thread.sleep(1000);
System.out.print("請輸入:");
asynParamsProcessor.getQueue().put(input.next());
}
}
}
執(zhí)行結(jié)果
請輸入:Java異步責任鏈
asynParamsProcessor>>>>>>>>>>Java異步責任鏈
asynCheckProcessor>>>>>>>>>>Java異步責任鏈
asynFinalProcessor>>>>>>>>>>Java異步責任鏈
到此這篇關(guān)于Java 設計模式之責任鏈模式及異步責任鏈詳解的文章就介紹到這了,更多相關(guān)Java 設計模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用MyBatis 動態(tài)update數(shù)據(jù)
使用mybatis寫sql,需要動態(tài)更新對象數(shù)據(jù),每次需要更新的字段不同,為了防止null空異常,就需要用動態(tài)sql了,下面給大家分享一段代碼關(guān)于mybatis動態(tài)update,需要的朋友參考下2016-11-11
java模板引擎Thymeleaf和前端vue的區(qū)別及說明
這篇文章主要介紹了java模板引擎Thymeleaf和前端vue的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
SpringBoot攔截器實現(xiàn)項目防止接口重復提交
基于SpringBoot框架來開發(fā)業(yè)務后臺項目時,接口重復提交是一個常見的問題,本文主要介紹了SpringBoot攔截器實現(xiàn)項目防止接口重復提交,具有一定的參考價值,感興趣的可以了解一下2023-09-09
Spring Cloud Hystrix 服務容錯保護的原理實現(xiàn)
這篇文章主要介紹了Spring Cloud Hystrix 服務容錯保護的原理實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05
Java 并發(fā)編程ArrayBlockingQueue的實現(xiàn)
這篇文章主要介紹了Java 并發(fā)編程ArrayBlockingQueue的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02

