設計模式之Decorator(油漆工)
板橋里人 http://www.jdon.com 2002/04/28
模式實(shí)戰書(shū)籍《Java實(shí)用系統開(kāi)發(fā)指南》
裝飾模式:Decorator常被翻譯成"裝飾",我覺(jué)得翻譯成"油漆工"更形象點(diǎn),油漆工(decorator)是用來(lái)刷油漆的,那么被刷油漆的對象我們稱(chēng)decoratee.這兩種實(shí)體在Decorator模式中是必須的.
Decorator定義:
動(dòng)態(tài)給一個(gè)對象添加一些額外的職責,就象在墻上刷油漆.使用Decorator模式相比用生成子類(lèi)方式達到功能的擴充顯得更為靈活.
為什么使用Decorator?
我們通??梢允褂美^承來(lái)實(shí)現功能的拓展,如果這些需要拓展的功能的種類(lèi)很繁多,那么勢必生成很多子類(lèi),增加系統的復雜性,同時(shí),使用繼承實(shí)現功能拓展,我們必須可預見(jiàn)這些拓展功能,這些功能是編譯時(shí)就確定了,是靜態(tài)的.
使用Decorator的理由是:這些功能需要由用戶(hù)動(dòng)態(tài)決定加入的方式和時(shí)機.Decorator提供了"即插即用"的方法,在運行期間決定何時(shí)增加何種功能.
如何使用?
舉Adapter中的打樁示例,在Adapter中有兩種類(lèi):方形樁圓形樁,Adapter模式展示如何綜合使用這兩個(gè)類(lèi),在Decorator模式中,我們是要在打樁時(shí)增加一些額外功能,比如,挖坑 在樁上釘木板等,不關(guān)心如何使用兩個(gè)不相關(guān)的類(lèi).
我們先建立一個(gè)接口:
| public interface Work } |
接口Work有一個(gè)具體實(shí)現:插入方形樁或圓形樁,這兩個(gè)區別對Decorator是無(wú)所謂.我們以插入方形樁為例:
| public class SquarePeg implements Work{ } |
現在有一個(gè)應用:需要在樁打入前,挖坑,在打入后,在樁上釘木板,這些額外的功能是動(dòng)態(tài),可能隨意增加調整修改,比如,可能又需要在打樁之后釘架子(只是比喻).
那么我們使用Decorator模式,這里方形樁SquarePeg是decoratee(被刷油漆者),我們需要在decoratee上刷些"油漆",這些油漆就是那些額外的功能.
| public class Decorator implements Work{ private Work work; //在構造器中使用組合new方式,引入Work對象; others.add("釘木板"); public void insert(){ newMethod();
public void otherMethod() } |
在上例中,我們把挖坑和釘木板都排在了打樁insert前面,這里只是舉例說(shuō)明額外功能次序可以任意安排.
好了,Decorator模式出來(lái)了,我們看如何調用:
Work squarePeg = new SquarePeg();
Work decorator = new Decorator(squarePeg);
decorator.insert();
Decorator模式至此完成.
如果你細心,會(huì )發(fā)現,上面調用類(lèi)似我們讀取文件時(shí)的調用:
FileReader fr = new FileReader(filename);
BufferedReader br = new BufferedReader(fr);
實(shí)際上Java 的I/O API就是使用Decorator實(shí)現的,I/O變種很多,如果都采取繼承方法,將會(huì )產(chǎn)生很多子類(lèi),顯然相當繁瑣.
Jive中的Decorator實(shí)現
在論壇系統中,有些特別的字是不能出現在論壇中如"打倒XXX",我們需要過(guò)濾這些"反動(dòng)"的字體.不讓他們出現或者高亮度顯示.
在IBM Java專(zhuān)欄中專(zhuān)門(mén)談Jive的文章中,有談及Jive中ForumMessageFilter.java使用了Decorator模式,其實(shí),該程序并沒(méi)有真正使用Decorator,而是提示說(shuō):針對特別論壇可以設計額外增加的過(guò)濾功能,那么就可以重組ForumMessageFilter作為Decorator模式了.
所以,我們在分辨是否真正是Decorator模式,以及會(huì )真正使用Decorator模式,一定要把握好Decorator模式的定義,以及其中參與的角色(Decoratee 和Decorator).
設計模式如何在具體項目中應用見(jiàn)《Java實(shí)用系統開(kāi)發(fā)指南》
聯(lián)系客服