The Decorator Pattern :
attaches additional responsibilities to an object dynamically.
Decorators provide a flexible alternative to subclassing for extending functionality.
装饰模式就是给一个对象增加一些新的功能,而且是动态的,要求装饰对象和被装饰对象实现同一个接口,装饰对象持有被装饰对象的实例。
装饰模式的应用场景:
1、需要扩展一个类的功能。
2、动态的为一个对象增加功能,而且还能动态撤销。(继承不能做到这一点,继承的功能是静态的,不能动态增删。)
缺点:产生过多相似的对象,不易排错!
实例:
//装饰类
public class Decorator implements Sourceable {
private Sourceable source=null;
public Decorator(Sourceable source){
super();
this.source=source;
}
@Override
public void method(){
source.method();
System.out.println("the decoratro method");
}
//测试
public static void main(String[] args){
Sourceable sr=new Source();
sr.method();
//System.out.println("");
String s=System.getProperty("line.separator");
System.out.println(s);
Sourceable srdec=new Decorator(sr);
srdec.method();
}
}
//共同接口
interface Sourceable{
public void method();
}
//被装饰类
class Source implements Sourceable{
@Override
public void method(){
System.out.println("the original method");
}
}
本文详细介绍了装饰模式的概念及其应用场景。装饰模式允许在不改变原有对象的情况下为其动态地添加新功能,提供了一种比继承更为灵活的替代方案。文章通过具体代码示例展示了装饰模式的实现方式。
720

被折叠的 条评论
为什么被折叠?



