#动态代理模式链接
装饰模式
装饰模式定义
动态地给一个对象添加一些额外的职责。就增加功能来说,装饰者模式相比生成子类更加灵活。
装饰者模式的类图![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/901ec273f21515b97c1c368a1de33736.png)
- Component抽象构件
Component是一个接口或者是抽象类,就是定义我们最核心的对象,也是最原始的对象。
- ConcreteComponent具体构件
ConcreteComponent 是最核心,最原始,最基本的接口或者抽象类的实现,你要装饰的就是它
- Decorater装饰角色
一般是一个抽象类,做什么用哪?实现接口或者抽象方法,它里面可不一定有抽象方法,在他的属性里面必然有一个private变量指向Component抽象构件
- 具体装饰角色
ConcreteDecorateA和ConcreteDecorateB是两个具体的装饰类,你要把你最核心的,最基本的那个修饰成其他的东西。
装饰者模式实现
public abstract Component{
public abstract void operate();
}
public class ConcreteComponent extends Component{
@override
public void operate(){
System.out.print("Do things");
}
}
public abstract class Decotator extends Component{
private Component component;
public Decotator(Component _component){
this.component = _component;
}
@override
public void operate(){
this.component.operate();
}
}
public class ConcreteDectoratorA extends Decotator {
public ConcreteDectorator(Component _component){
super(_component);
}
// 定义自己修饰的方法
private void method1(){
System.out.print("这是修饰方法1");
}
@override
public void operate(){
super.operate();
this.method1();
}
}
public class ConcreteDectoratorB extends Decotator {
public ConcreteDectorator(Component _component){
super(_component);
}
// 定义自己修饰的方法
private void method2(){
System.out.print("这是修饰方法2");
}
@override
public void operate(){
super.operate();
this.method2();
}
}
class User{
public static void main(String[] args) {
Component c = new ConcreteComponent();
//装饰A
c = new ConcreteDectoratorA(c);
//装饰B
c = new ConcreteDectoratorB(c);
//这里涉及一个Java多态,ConcreteDectoratorB对象调用super.operate()->super.sr==ConcreteDectoratorA对象
//同样的在ConcreteDectoratorA对象super.operate()->super.sr==ConcreteComponent对象
//ConcreteComponent对象的operate()开始运行,然后向下运行ConcreteDectoratorA的method1,然后运行method2
c.operate();
}
}
#装饰者模式的优点:
- 装饰类和被装饰类可以独立发展,而不会相互耦合。换句话说,Component类无须知
道Decorator类,Decorator类是从外部来扩展Component类的功能,而Decorator也不用知道具
体的构件。 - 装饰模式是继承关系的一个替代方案。我们看装饰类Decorator,不管装饰多少层,返
回的对象还是Component,实现的还是is-a的关系。 - 装饰模式可以动态地扩展一个实现类的功能,这不需要多说,装饰模式的定义就是如
此
#装饰者模式的缺点
对于装饰模式记住一点就足够了:多层的装饰是比较复杂的。为什么会复杂呢?你想想
看,就像剥洋葱一样,你剥到了最后才发现是最里层的装饰出现了问题,想象一下工作量
吧,因此,尽量减少装饰类的数量,以便降低系统的复杂度
装饰者模式的使用场景
● 需要扩展一个类的功能,或给一个类增加附加功能。
● 需要动态地给一个对象增加功能,这些功能可以再动态地撤销。
● 需要为一批的兄弟类进行改装或加装功能,当然是首选装饰模式。