装饰器模式
装饰器模式的定义:
动态的给一个对象添加额外的职责,就功能来说,装饰模式相比子类更为灵活
装饰器模式的四个角色:
- Componment 抽象构建角色:该角色用于规范需要装饰的对象
- ConcreateComponment 具体构建角色:该角色是需要被装饰地 对象
- Decorator: 装饰角色:一般是一个抽象类,该角色持有私有的一个抽象构件对象
- ConcreateDecorator: 具体装饰角色;感觉主要负责对构件对象进行装饰
装饰器模式的简单示例
抽象构件角色
public interface Componment {
public void doingProcedureA();
}
具体构件角色
public class ConcreteComponmentA implements Componment {
@Override
public void doingProcedureA() {
System.out.println("Componment A is doing ProcedureA");
}
}
装饰角色
public abstract class Decorator implements Componment {
protected Componment component;
public Decorator(Componment componment) {
this.component = componment;
}
@Override
public void doingProcedureA() {
component.doingProcedureA();
}
}
具体装饰角色
在具体装饰角色中,我们需要加入装饰方法,并将装饰方法在构建的方法中进行调用
public class ConcreateDecorator extends Decorator {
public ConcreateDecorator(Componment componment) {
super(componment);
}
public void extraFunction() {
System.out.println("Doing Extara Function");
}
public void doingProcedureA() {
this.extraFunction();
super.doingProcedureA();
}
}
调用展示
public class Client {
public static void main(String[] args) {
Componment componment = new ConcreteComponmentA();
componment = new ConcreateDecorator(componment);
componment = new ConcreateDecorator(componment);
componment.doingProcedureA();
}
}
装饰器模式的优点和使用范围
装饰器模式的优点:
- 装饰类和被装饰类可以独立发展,而不会相互耦合
- 装饰模式是继承关系的一种替代方案
- 装饰模式可以动态的扩展一个实现类的功能
装饰器模式的应用场景:
- 用于扩展一个类的功能,或者给一个类添加附加职责
- 动态的给一个对象天机功能,这些功能可以被动态的撤销
- 需要位一批的兄弟类进行改装或加装功能
装饰器模式的缺点:
- 多层的装饰较为复杂