亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java設(shè)計(jì)模式之責(zé)任鏈模式(Chain of Responsibility模式)介紹

 更新時間:2015年03月11日 09:45:54   投稿:junjie  
這篇文章主要介紹了Java設(shè)計(jì)模式之責(zé)任鏈模式(Chain of Responsibility模式)介紹,本文講解了如何使用責(zé)任鏈模式,并給出了4種使用實(shí)例,需要的朋友可以參考下

Chain of Responsibility定義:Chain of Responsibility(CoR) 是用一系列類(classes)試圖處理一個請求request,這些類之間是一個松散的耦合,唯一共同點(diǎn)是在他們之間傳遞request。也就是說,來了一個請求,A類先處理,如果沒有處理,就傳遞到B類處理,如果沒有處理,就傳遞到C類處理,就這樣象一個鏈條(chain)一樣傳遞下去。

如何使用責(zé)任鏈模式
雖然這一段是如何使用CoR,但是也是演示什么是CoR。

有一個Handler接口:

復(fù)制代碼 代碼如下:

public interface Handler{
  public void handleRequest();
}

這是一個處理request的事例, 如果有多種request,比如 請求幫助 請求打印 或請求格式化:
◆ 最先想到的解決方案是:在接口中增加多個請求:
復(fù)制代碼 代碼如下:

public interface Handler{
  public void handleHelp();
  public void handlePrint();
  public void handleFormat();
}

具體是一段實(shí)現(xiàn)接口Handler代碼:

復(fù)制代碼 代碼如下:

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

  public void handleHelp(){
    //具體處理請求Help的代碼
    ...
  }

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

}

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

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

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

復(fù)制代碼 代碼如下:

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;}

}

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


◆ 解決方案3:在Handler接口中只使用一個參數(shù)化方法:

復(fù)制代碼 代碼如下:

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
      //傳遞到下一個
      successor.handle(request);

    }
  }

}

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

◆ 最后解決方案:接口Handler的代碼如下:

復(fù)制代碼 代碼如下:

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)代碼如下:
復(fù)制代碼 代碼如下:

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
      //傳遞到下一個
      successor.handle(request);

    }
  }

}

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

1.CoR的優(yōu)點(diǎn):因?yàn)闊o法預(yù)知來自外界的請求是屬于哪種類型,每個類如果碰到它不能處理的請求只要放棄就可以。無疑這降低了類之間的耦合性。
2.CoR的缺點(diǎn)是效率低,因?yàn)橐粋€請求的完成可能要遍歷到最后才可能完成,當(dāng)然也可以用樹的概念優(yōu)化。 在Java AWT1.0中,對于鼠標(biāo)按鍵事情的處理就是使用CoR,到Java.1.1以后,就使用Observer代替CoR。

擴(kuò)展性差,因?yàn)樵贑oR中,一定要有一個統(tǒng)一的接口Handler.局限性就在這里。

相關(guān)文章

  • 2020年IntelliJ IDEA最新最詳細(xì)配置圖文教程詳解

    2020年IntelliJ IDEA最新最詳細(xì)配置圖文教程詳解

    這篇文章主要介紹了2020年IntelliJ IDEA最新最詳細(xì)配置圖文教程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • java數(shù)組排序示例分享

    java數(shù)組排序示例分享

    這篇文章主要介紹了java數(shù)組排序示例,需要的朋友可以參考下
    2014-03-03
  • Android studio按鈕點(diǎn)擊頁面跳轉(zhuǎn)詳細(xì)步驟

    Android studio按鈕點(diǎn)擊頁面跳轉(zhuǎn)詳細(xì)步驟

    在Android應(yīng)用程序中,頁面跳轉(zhuǎn)是非常常見的操作,下面這篇文章主要給大家介紹了關(guān)于Android studio按鈕點(diǎn)擊頁面跳轉(zhuǎn)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • java使用hashMap緩存保存數(shù)據(jù)的方法

    java使用hashMap緩存保存數(shù)據(jù)的方法

    這篇文章主要介紹了java使用hashMap緩存保存數(shù)據(jù)的方法,結(jié)合實(shí)例形式簡單分析了java基于hashmap讀寫緩存數(shù)據(jù)的相關(guān)操作技巧,需要的朋友可以參考下
    2016-08-08
  • JVM如何處理異常深入詳解

    JVM如何處理異常深入詳解

    異常處理的兩大元素:拋出異常、捕獲異常,非正常處理的兩個方法。下面這篇文章主要給大家介紹了關(guān)于JVM如何處理異常的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2019-01-01
  • idea resources目錄下的application.properties不能自動提示問題

    idea resources目錄下的application.properties不能自動提示問題

    這篇文章主要介紹了idea resources目錄下的application.properties不能自動提示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Spring Boot 開發(fā)環(huán)境熱部署詳細(xì)教程

    Spring Boot 開發(fā)環(huán)境熱部署詳細(xì)教程

    這篇文章主要介紹了Spring Boot 開發(fā)環(huán)境熱部署,本文給大家介紹了Spring Boot 開發(fā)環(huán)境熱部署的原理及快速配置方法,通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • SpringMVC MVC架構(gòu)與Servlet使用詳解

    SpringMVC MVC架構(gòu)與Servlet使用詳解

    MVC設(shè)計(jì)模式一般指 MVC 框架,M(Model)指數(shù)據(jù)模型層,V(View)指視圖層,C(Controller)指控制層。使用 MVC 的目的是將 M 和 V 的實(shí)現(xiàn)代碼分離,使同一個程序可以有不同的表現(xiàn)形式。其中,View 的定義比較清晰,就是用戶界面
    2022-10-10
  • 使用MQ消息隊(duì)列的優(yōu)缺點(diǎn)詳解

    使用MQ消息隊(duì)列的優(yōu)缺點(diǎn)詳解

    這篇文章主要介紹了使用MQ消息隊(duì)列的優(yōu)缺點(diǎn)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • Java仿Windows記事本源代碼分享

    Java仿Windows記事本源代碼分享

    這篇文章主要為大家詳細(xì)介紹了Java仿Windows記事本源代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03

最新評論