Java 代理模式和裝飾者模式的區別


裝飾模式:以對客戶端透明的方式擴展對象的功能,是繼承關系的一個替代方案;
代理模式:給一個對象提供一個代理對象,並有代理對象來控制對原有對象的引用


裝飾模式應該為所裝飾的對象增強功能;代理模式對代理的對象施加控制,並不提供對象本身的增強功能

二者的實現機制確實是一樣的,可以看到他們的實例代碼重復是很多的。但就語義上說,這兩者的功能是相反的,模式的一個重要作用是簡化其他程序員對你程序的理解,

你在一個地方寫裝飾,大家就知道這是在增加功能,你寫代理,大家就知道是在限制

雖然代碼很可能相同,但如果你都叫他們裝飾,別人會很迷惑的。

--------------------------------------------------------------

學習AOP時,教材上面都說使用的是動態代理,可是在印象中代理模式一直都是控制訪問什么的,怎么又動態增加行為了,動態增加行為不是裝飾器模式嗎?於是 找了很多資料,想弄清楚這兩者之間到底有什么區別。結果發現這一篇英文文章講的很清晰,就翻譯一下,供參考。       

        首先,讓我們先看一下下面的這兩個UML類圖,他們分別描述了裝飾器模式和代理模式的基本實現。

                    

                     

        這兩個圖可能使我們產生困惑。這兩個設計模式看起來很像。對裝飾器模式來說,裝飾者(decorator)和被裝飾者(decoratee)都實現同一個 接口。對代理模式來說,代理類(proxy class)和真實處理的類(real class)都實現同一個接口。此外,不論我們使用哪一個模式,都可以很容易地在真實對象的方法前面或者后面加上自定義的方法。

        然而,實際上,在裝飾器模式和代理模式之間還是有很多差別的。裝飾器模式關注於在一個對象上動態的添加方法,然而代理模式關注於控制對對象的訪問。換句話 說,用代理模式,代理類(proxy class)可以對它的客戶隱藏一個對象的具體信息。因此,當使用代理模式的時候,我們常常在一個代理類中創建一個對象的實例。並且,當我們使用裝飾器模 式的時候,我們通常的做法是將原始對象作為一個參數傳給裝飾者的構造器。

        我們可以用另外一句話來總結這些差別:使用代理模式,代理和真實對象之間的的關系通常在編譯時就已經確定了,而裝飾者能夠在運行時遞歸地被構造。    

代理模式:

復制代碼
//代理模式
public class Proxy implements Subject{

private Subject subject;
public Proxy(){
//關系在編譯時確定
subject = new RealSubject();
}
public void doAction(){
….
subject.doAction();
….
}
}
復制代碼
復制代碼
//代理的客戶
public class Client{
public static void main(String[] args){
//客戶不知道代理委托了另一個對象
Subject subject = new Proxy();

}
}
復制代碼

裝飾模式:

復制代碼
//裝飾器模式
public class Decorator implements Component{
private Component component;
public Decorator(Component component){
this.component = component
}
public void operation(){
….
component.operation();
….
}
}
復制代碼
復制代碼
//裝飾器的客戶
public class Client{
public static void main(String[] args){
//客戶指定了裝飾者需要裝飾的是哪一個類
Component component = new Decorator(new ConcreteComponent());

}
}
復制代碼

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM