久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

設(shè)計(jì)模式之Chain of Responsibility(職責(zé)鏈)

 HaiLan 2006-09-14
設(shè)計(jì)模式之Chain of Responsibility(職責(zé)鏈)
 
Chain of Responsibility定義
Chain of Responsibility(CoR)
是用一系列類(classes)試圖處理一個(gè)請(qǐng)求request,這些類之間是一個(gè)松散的耦合,唯一共同點(diǎn)是在他們之間傳遞request. 也就是說(shuō),來(lái)了一個(gè)請(qǐng)求,,A類先處理,,如果沒(méi)有處理,就傳遞到B類處理,,如果沒(méi)有處理,,就傳遞到C類處理,就這樣象一個(gè)鏈條(chain)一樣傳遞下去,。

如何使用?
雖然這一段是如何使用CoR,但是也是演示什么是CoR.

有一個(gè)Handler接口:

public interface Handler{
  public void handleRequest();
}

這是一個(gè)處理request的事例,, 如果有多種request,比如 請(qǐng)求幫助 請(qǐng)求打印 或請(qǐng)求格式化:

最先想到的解決方案是:在接口中增加多個(gè)請(qǐng)求:
public interface Handler{
  public void handleHelp();
  
public void handlePrint();
  public void handleFormat();

}

具體是一段實(shí)現(xiàn)接口Handler代碼:
public class ConcreteHandler implements Handler{
  private Handler successor;

  public ConcreteHandler(Handler successor){
  
this.successor=successor;
}

  public void handleHelp(){
    //具體處理請(qǐng)求Help的代碼

    ...
  }

  public void handlePrint(){
    //如果是print 轉(zhuǎn)去處理
Print
    
successor.handlePrint();
  
}
  
public void handleFormat(){
    //如果是Format 轉(zhuǎn)去處理
format
    
successor.handleFormat();
  }

}
一共有三個(gè)這樣的具體實(shí)現(xiàn)類,上面是處理help,還有處理Print 處理Format這大概是我們最常用的編程思路,。

雖然思路簡(jiǎn)單明了,,但是有一個(gè)擴(kuò)展問(wèn)題,,如果我們需要再增加一個(gè)請(qǐng)求request種類,需要修改接口及其每一個(gè)實(shí)現(xiàn),。

第二方案:將每種request都變成一個(gè)接口,因此我們有以下代碼 :

public interface HelpHandler{
  public void handleHelp();
}

public interface PrintHandler{
  public void handlePrint();
}

public interface FormatHandler{
  public void handleFormat();
}

public class ConcreteHandler
  implements HelpHandler,PrintHandler,FormatHandlet{
  
private HelpHandler helpSuccessor;
  
private PrintHandler printSuccessor;
  private FormatHandler formatSuccessor;

  public ConcreteHandler(HelpHandler helpSuccessor,PrintHandler printSuccessor,FormatHandler             formatSuccessor)
  
{
    
this.helpSuccessor=helpSuccessor;
    
this.printSuccessor=printSuccessor;
    
this.formatSuccessor=formatSuccessor;
  }

  public void handleHelp(){
    
.......
  }

  public void handlePrint(){this.printSuccessor=printSuccessor;}

  public void handleFormat(){this.formatSuccessor=formatSuccessor;}

}

這個(gè)辦法在增加新的請(qǐng)求request情況下,,只是節(jié)省了接口的修改量,,接口實(shí)現(xiàn)ConcreteHandler還需要修改。而且代碼顯然不簡(jiǎn)單美麗,。

解決方案3: Handler接口中只使用一個(gè)參數(shù)化方法:
public interface Handler{
  public void handleRequest(String request);
}
那么Handler實(shí)現(xiàn)代碼如下:

public class ConcreteHandler implements Handler{
  private Handler successor;

  public ConcreteHandler(Handler successor){
    
this.successor=successor;
  }

  public void handleRequest(String request){
    
if (request.equals("Help")){
      //這里是處理Help的具體代碼

    }else
      //傳遞到下一個(gè)

      successor.handle(request);

    }
  }

}

這里先假設(shè)requestString類型,,如果不是怎么辦?當(dāng)然我們可以創(chuàng)建一個(gè)專門類Request

最后解決方案:接口Handler的代碼如下:
public interface Handler{
  public void handleRequest(Request request);
}
Request
類的定義
:
public class Request{
  
private String type;

  public Request(String type){this.type=type;}

  public String getType(){return type;}

  public void execute(){
    //request真正具體行為代碼

  }
}
那么Handler實(shí)現(xiàn)代碼如下:

public class ConcreteHandler implements Handler{
  private Handler successor;

  public ConcreteHandler(Handler successor){
    
this.successor=successor;
  }

  public void handleRequest(Request request){
    
if (request instanceof HelpRequest){
      //這里是處理Help的具體代碼

    }else if (request instanceof PrintRequst){
      
request.execute();
    
}else
      //傳遞到下一個(gè)

      successor.handle(request);

    }
  }

}

這個(gè)解決方案就是CoR, 在一個(gè)鏈上,都有相應(yīng)職責(zé)的類,因此叫Chain of Responsibility.

CoR的優(yōu)點(diǎn):
因?yàn)闊o(wú)法預(yù)知來(lái)自外界(客戶端)的請(qǐng)求是屬于哪種類型,,每個(gè)類如果碰到它不能處理的請(qǐng)求只要放棄就可以,。

缺點(diǎn)是效率低,因?yàn)橐粋€(gè)請(qǐng)求的完成可能要遍歷到最后才可能完成,,當(dāng)然也可以用樹的概念優(yōu)化,。 在Java AWT1.0中,對(duì)于鼠標(biāo)按鍵事情的處理就是使用CoR,Java.1.1以后,,就使用Observer代替CoR

擴(kuò)展性差,,因?yàn)樵?span lang=EN-US>CoR中,,一定要有一個(gè)統(tǒng)一的接口Handler.局限性就在這里。

Command模式區(qū)別:

Command 模式需要事先協(xié)商客戶端和服務(wù)器端的調(diào)用關(guān)系,,比如 1 代表 start 2 代表 move 等,,這些 都是封裝在 request 中,到達(dá)服務(wù)器端再分解,。

CoR 模式就無(wú)需這種事先約定,,服務(wù)器端可以使用 CoR 模式進(jìn)行客戶端請(qǐng)求的猜測(cè),一個(gè)個(gè)猜測(cè) 試驗(yàn),。

 

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多