装饰模式(decorator)
概念:装饰模式就是给一个对象增加一些新的功能,而且是动态的,要求装饰对象和被装饰对象实现同一个接口,装饰对象持有被装饰对象的实例。
适用:
1、需要扩展一个类的功能。
2、动态的为一个对象增加功能,而且还能动态撤销。
装饰模式与代理模式的区别:
装饰模式关注于在一个对象上动态的添加方法,然而代理模式关注于控制对对象的访问。用代理模式,代理类(proxy class)可以对它的客户隐藏一个对象的具体信息。因此,当使用代理模式的时候,我们常常在一个代理类中创建一个对象的实例。并且,当我们使用装饰器模 式的时候,我们通常的做法是将原始对象作为一个参数传给装饰者的构造器。
代码示例:
/**
* 抽象接口,可以动态的给这些对象添加属性和方法
*/
public interface Component {
public void operation();
}
/**
* 被装饰类
* 具体的对象,可以动态的给这些对象添加属性和方法
*/
public class ConcreteComponent implements Component {
public void operation() {
System.out.println("operation...");
}
}
/**
* 装饰类
* 从外类来扩展Component类的功能
*/
public class Decoartor implements Component {
private Component component;
public Decoartor(Component component){
this.component = component;
}
public void operation() {
component.operation();
}
}
/**
* 具体的装饰对象,给Component添加方法和属性的功能,通过Decorator的调度
*/
public class ConcreteDecoratorA extends Decoartor {
public ConcreteDecoratorA(Component component) {
super(component);
}
public void operation() {
System.out.println("A operation...");
super.operation();
}
}
/**
* 装饰模式的测试
* 装饰模式就是给一个对象增加一些新的功能,而且是动态的,要求装饰对象和被装饰对象实现同一个接口,装饰对象持有被装饰对象的实例
* 装饰器模式关注于在一个对象上动态的添加方法,然而代理模式关注于控制对对象的访问;
* 用代理模式,代理类(proxy class)可以对它的客户隐藏一个对象的具体信息,因此,当使用代理模式的时候,我们常常在一个代理类中创建一个对象的实例;
* 使用装饰器模式的时候,我们通常的做法是将原始对象作为一个参数传给装饰者的构造器
*/
public class Test {
public static void main(String[] args) {
Component c = new ConcreteComponent();
Component concreteDecoratorA = new ConcreteDecoratorA(c);
concreteDecoratorA.operation();
}
}