Java設計模式之責任鏈模式的示例詳解_第1頁
Java設計模式之責任鏈模式的示例詳解_第2頁
Java設計模式之責任鏈模式的示例詳解_第3頁
Java設計模式之責任鏈模式的示例詳解_第4頁
Java設計模式之責任鏈模式的示例詳解_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第Java設計模式之責任鏈模式的示例詳解目錄應用場景實際代碼案例無模式情況下的代碼采用責任鏈模式優(yōu)化代碼采用建造者+責任鏈模式優(yōu)化代碼責任鏈模式優(yōu)缺點責任鏈模式是將鏈中的每一個節(jié)點看做是一個對象,每個節(jié)點處理的請求均不相同,且內部自動維護下一個節(jié)點對象,當一個請求從鏈式的首段發(fā)出時,會沿著鏈的路徑依次傳遞給每一個節(jié)點對象,直至有對象處理這個請求位置,屬于行為模式。

這里需要注意的是每個節(jié)點都能對對象進行一定的處理(也可以不處理),處理完成之后節(jié)點再進行判斷還要進行后續(xù)處理還是說傳遞給下一個節(jié)點。

應用場景

首先舉一個日常的例子,比如我們申請開發(fā)票,首先我們要寫好報銷單,首先要你的部門領導審批,部門領導審批不通過直接打回,審批通過再由公司的總經(jīng)理審批這里審批通過才算成審批完成。這種情況就很適合使用責任鏈模式。

總結一下責任鏈主要適用一下幾種情況:

多個對象可以處理同一個請求,但是具體由那個對象處理完成則在運行時決定。不明確指定接收者的情況下,向多個對象中的一個提交一個請求

可以看一下責任鏈模式的通用UML類圖:

通過類圖可以看到總共包含以下角色:

抽象處理者:主要是定義處理請求的方法以及維護下一個處理結點的對象的引用具體處理者:處理的具體實現(xiàn)

責任鏈的精髓在于將很多處理節(jié)點行成個鏈式結構,并允許結點自身決定是否進行處理或者轉發(fā)。

實際代碼案例

下面舉一個我們在開發(fā)時經(jīng)常會遇到的一種情況:登錄比如我們開發(fā)一個管理系統(tǒng)在登錄的時候往往我們會先判斷客戶端傳遞的賬號及密碼是否為空但凡有一個是空肯定是不能繼續(xù)往下走的,然后就是根據(jù)用戶賬號密碼拿到用戶的所有信息,如果能拿到繼續(xù)周下一步,拿不到則是報錯提示用戶不存在,到下一步又會判斷當前用戶的權限。

無模式情況下的代碼

privateStringlogin(Stringusername,Stringpassword){

if(username==null||password==null){

return"賬戶或者密碼為null";

Useruser=queryUserInfo(username,password);

if(user==null){

return"找不到用戶";

if(!Objects.equals(user.getRoleName(),"超管")){

return"沒有權限";

return"登錄成功";

privateUserqueryUserInfo(Stringusername,Stringpassword){

if(Objects.equals(username,"土豆")Objects.equals(password,"666666")){

returnnewUser(username,password,"超管");

}elseif(Objects.equals(username,"土豆2號")Objects.equals(password,"666666")){

returnnewUser(username,password,"普通員工");

returnnull;

}

發(fā)現(xiàn)判斷代碼都冗余在一個方法里面,后續(xù)改動修改都需要修改中這個方法不滿足開閉原則。

采用責任鏈模式優(yōu)化代碼

首先創(chuàng)建抽象類規(guī)定抽象方法以及維護下一個節(jié)點

publicabstractclassHandler{

protectedHandlernext;

publicvoidsetNext(Handlernext){

this.next=next;

publicabstractvoiddoHandler(Useruser);

}

然后就是創(chuàng)建多個實現(xiàn)邏輯的節(jié)點對象:

publicclassValidatedHandlerextendsHandler{

@Override

publicvoiddoHandler(Useruser){

if(user.getUsername()==null||user.getPassword()==null){

System.out.println("賬戶或者密碼為null");

}else{

this.next.doHandler(user);

}

publicclassUserHandlerextendsHandler{

@Override

publicvoiddoHandler(Useruser){

queryUserInfo(user);

if(user.getRoleName()==null){

System.out.println("沒有找到用戶");

}else{

this.next.doHandler(user);

privatestaticvoidqueryUserInfo(Useruser){

if(Objects.equals(user.getUsername(),"土豆")Objects.equals(user.getPassword(),"666666")){

user.setRoleName("超管");

}elseif(Objects.equals(user.getUsername(),"土豆2號")Objects.equals(user.getPassword(),"666666")){

user.setRoleName("普通員工");

}

publicclassAuthHandlerextendsHandler{

@Override

publicvoiddoHandler(Useruser){

if(!Objects.equals(user.getRoleName(),"超管")){

System.out.println("沒有權限");

System.out.println("登入成功");

}

最后調用:

publicstaticvoidmain(String[]args){

Useruser=newUser("土豆","666666");

HandlervalidatedHandler=newValidatedHandler();

HandleruserHandler=newUserHandler();

HandlerauthHandler=newAuthHandler();

validatedHandler.setNext(userHandler);

userHandler.setNext(authHandler);

validatedHandler.doHandler(user);

}

可以看一下UML類圖:

采用建造者+責任鏈模式優(yōu)化代碼

上述的代碼發(fā)現(xiàn)維護鏈表的操作在用戶調用的那一層,鏈表的組裝過于復雜,這個時候我們可以使用建造者模式,自動維護鏈表的組裝,調用者只需要指定鏈表的順序即可主要修改Handler內代碼:

publicabstractclassHandler{

protectedHandlernext;

publicvoidsetNext(Handlernext){

this.next=next;

publicabstractvoiddoHandler(Useruser);

publicstaticclassBuilder{

privateHandlerhead;

privateHandlertail;

publicBuilderaddHandler(Handlerhandler){

if(this.head==null){

this.head=this.tail=handler;

returnthis;

this.tail.setNext(handler);

this.tail=handler;

returnthis;

publicHandlerbuild(){

returnthis.head;

}

Handler.Builderbuilder=newHandler.Builder();

builder.addHandler(newValidatedHandler())

.addHandler(newUserHandler())

.addHandler(newAuthHandler());

b

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論