概念
裝飾者模式動態地將責任附加到物件上。若要擴展功能,裝飾者提供了比繼承更有彈性的替代方案。
裝飾者和被裝飾物件有相同的超類型。
你可以用一個或多個裝飾者包裝一個物件。
既然裝飾者和被裝飾物件有相同的超類型,所以在任何需要原始物件(被包裝的)的場合 ,可以用裝飾過的物件代替它。
裝飾者可以在所委託被裝飾者的行為之前與/或之後,加上自己的行為,以達到特定的目的。
物件可以在任何時候被裝飾,所以可以在運行時動態地、不限量地用你喜歡的裝飾者來裝飾
物件。
在Java中,io包下的許多類別就是典型的裝飾者模式的體現,如:
new BufferedOutputStream(OutputStream out)
new BufferedInputStream(InputStream in); new FilterReader(Reader in);
裝飾類與被裝飾的類實現相同的接口,
被裝飾類,不關心具體是哪個實現類來裝飾它,同樣的業務方法,被裝飾類調用裝飾類的方法,增強裝飾類別的功能
實例:
類別圖
public interface IReader { void read(); } public class Reader implements IReader { @Override public void read() { System.out.println("read of Reader"); } } public class BufferedReader implements IReader { private IReader mReader; public BufferedReader(IReader reader) { this.mReader = reader; } @Override public void read() { System.out.println("read of BufferedReader"); mReader.read(); } } public class Test { public static void main(String[] args) { Reader reader = new Reader(); reader.read(); System.out.println("----------"); BufferedReader bufferedReader = new BufferedReader(reader); bufferedReader.read(); } }
1.裝飾物件和真實物件有相同的介面。這樣客戶端物件就能以和真實物件相同的方式和裝飾物件互動。 2.裝飾物件包含一個真實物件的引用(reference)
3.裝飾物件接受所有來自客戶端的請求。它把這些請求轉發給真實的物件。4.裝飾物件可以在轉送這些請求以前或以後增加一些附加功能。這樣就確保了在運行時,不用修改給定物件的結構就可以在外部增加附加的功能。
在物件導向的設計中,通常是透過繼承來實現對給定類別的功能擴展。而裝飾後,持有了真實對象,用以增強其功能。
裝飾者與適配器模式的區別:
關於新職責:適配器也可以在轉換時增加新的職責,但主要目的不在此。裝飾者模式主要是為被裝飾者增加新職責的。
關於其包裹的物件:適配器是知道被適配者的詳細情況的(就是適配類別)。裝飾者只知道其介面是什麼,
至於其具體類型(是基底類別還是其他衍生類別)只有在運作期間才知道。
更多舉例講解Java設計模式編程中Decorator裝飾者模式的運用相關文章請關注PHP中文網!