2023-06-15
原文作者: 求和的小熊猫 原文地址:https://blog.csdn.net/qq_38219153/article/details/110894623

装饰器模式

装饰器模式的定义:
动态的给一个对象添加额外的职责,就功能来说,装饰模式相比子类更为灵活

装饰器模式的四个角色:

  • Componment 抽象构建角色:该角色用于规范需要装饰的对象
  • ConcreateComponment 具体构建角色:该角色是需要被装饰地 对象
  • Decorator: 装饰角色:一般是一个抽象类,该角色持有私有的一个抽象构件对象
  • ConcreateDecorator: 具体装饰角色;感觉主要负责对构件对象进行装饰
装饰器模式的简单示例

202306152220232531.png

抽象构件角色

    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();
    	}
    
    }
装饰器模式的优点和使用范围

装饰器模式的优点:

  • 装饰类和被装饰类可以独立发展,而不会相互耦合
  • 装饰模式是继承关系的一种替代方案
  • 装饰模式可以动态的扩展一个实现类的功能

装饰器模式的应用场景:

  • 用于扩展一个类的功能,或者给一个类添加附加职责
  • 动态的给一个对象天机功能,这些功能可以被动态的撤销
  • 需要位一批的兄弟类进行改装或加装功能

装饰器模式的缺点:

  • 多层的装饰较为复杂
阅读全文