1. 定义
装饰模式:动态地给一个对象添加一些额外的职责。就增加功能来说,装饰模式相比生成子类更为灵活。装饰模式中,通过装饰者给被装饰者扩展了功能。
2. 使用场景
- 需要扩展一个类的功能,或给一个类增加附加功能。
- 需要动态地给一个对象增加功能,这些功能可以再动态地撤销。
- 需要为一批的兄弟类进行改装或加装功能,当然是首选装饰模式。
- Java中的IO流的架构。
- Android中的Context家族。
3. 实现
被装饰者的抽象及其实现:
public abstract class Component {
public abstract void operate();
}
public class ConcreteComponent extends Component {
@Override
public void operate() {
System.out.println("operate");
}
}
装饰者的抽象:
public abstract class Decorator extends Component {
private Component mComponent;
public Decorator(Component component) {
mComponent = component;
}
@Override
public void operate() {
//委托给被修饰者去执行对应的方法
this.mComponent.operate();
}
}
装饰者的具体实现:
public class ConcreteDecorator1 extends Decorator{
public ConcreteDecorator1(Component component) {
super(component);
}
@Override
public void operate() {
decorate1();
super.operate();
}
public void decorate1() {
System.out.println("修饰方法1");
}
}
public class ConcreteDecorator2 extends Decorator {
public ConcreteDecorator2(Component component) {
super(component);
}
@Override
public void operate() {
decorate2();
super.operate();
}
public void decorate2() {
System.out.println("修饰方法2");
}
}
场景类:
public class Client {
public static void main(String[] args) {
Component component = new ConcreteDecorator1(new ConcreteDecorator2(new ConcreteComponent()));
component.operate();
}
}
运行结果:
修饰方法1
修饰方法2
operate
4. 优点
- 装饰模式可以动态地扩展一个实现类的功能。
- 装饰模式是继承关系的一个替代方案。不管装饰多少层,最终返回的对象还是抽象类。
- 装饰类和被装饰类可以独立发展,而不会相互耦合。
5. 缺点
- 多层的装饰是比较复杂的。
- 应该尽量减少装饰类的数量,以便降低系统的复杂度。