前言:【模式總覽】——————————by xingoohtml
避免請求的發送者,和接受者過分的耦合在一塊兒。一個請求者只須要發送一個請求便可,它的請求具體由後面哪一個對象進行響應,並不須要關心。而請求的接受者能夠本身處理它,也能夠把它像鏈條同樣向後傳。安全
所以,請求也就意味着有可能丟失,或者說沒有確切的安全保障。ide
1 下降耦合度this
2 加強指派職責的靈活性spa
3 不保證被接受code
Handler 定義一個接口,實現向後傳遞的過程htm
1 abstract class Handler{ 2 protected Handler successor; 3 4 public abstract void handleRequest(); 5 6 public Handler getSuccessor() { 7 return successor; 8 } 9 10 public void setSuccesor(Handler successor) { 11 this.successor = successor; 12 } 13 14 }
ConcreteHandler 能夠負責請求,也能夠向後傳遞對象
1 class ConcreteHandler extends Handler{ 2 public void handleRequest(){ 3 if(getSuccessor() != null){ 4 System.out.println("getSuccessor !"); 5 getSuccessor().handleRequest(); 6 }else{ 7 System.out.println("handle in this! request()!"); 8 } 9 } 10 }
所有代碼blog
1 package com.xingoo; 2 abstract class Handler{ 3 protected Handler successor; 4 5 public abstract void handleRequest(); 6 7 public Handler getSuccessor() { 8 return successor; 9 } 10 11 public void setSuccesor(Handler successor) { 12 this.successor = successor; 13 } 14 15 } 16 class ConcreteHandler extends Handler{ 17 public void handleRequest(){ 18 if(getSuccessor() != null){ 19 System.out.println("getSuccessor !"); 20 getSuccessor().handleRequest(); 21 }else{ 22 System.out.println("handle in this! request()!"); 23 } 24 } 25 } 26 public class Client { 27 public static void main(String[] args) { 28 Handler handle1,handle2,handle3; 29 handle1 = new ConcreteHandler(); 30 handle2 = new ConcreteHandler(); 31 handle3 = new ConcreteHandler(); 32 handle1.setSuccesor(handle2); 33 handle2.setSuccesor(handle3); 34 handle1.handleRequest(); 35 } 36 }
運行結果接口
getSuccessor ! getSuccessor ! handle in this! request()!