Head First 设计模式学习笔记——装饰者模式

时间:2022-06-22 07:59:04

Head First 设计模式学习笔记——装饰者模式简单理解

问题来源:     如何动态地扩展一个类,将新的特性或功能附加到类上?     通常可以使用继承的方式实现,在子类中重写父类的方法。如下图所示定义了两个类,其中Class2继承自Class1。与Class1相比,Class2中的getData()方法先将data值加1再return,而父类的方法直接将data返回。因此可以说Class2扩展了Class1的getData()方法,添加了新的功能。
    Head First 设计模式学习笔记——装饰者模式     但是直接使用继承存在一些问题,继承将父类与子类牢牢地捆绑起来,父类的改变会直接影响子类,当子类的数量很多时,父类一丁点的修改都会造成大量子类代码的修改。装饰者模式可以很好地解决这个问题,利用装饰着模式将Class1与Class2解耦,用Class2装饰Class1而非使用继承,在不修改Class1代码的基础上动态地扩展Class1。如下图所示,Class2 通过构造函数Class2(Class0 c0) 动态实例化Class1。 Head First 设计模式学习笔记——装饰者模式





与直接继承相比,装饰着模式提供了弹性更大的方案,通过少量代码的修改就可以扩展类。 实现上述类图的代码如下: Class0.java:
public abstract class Class0 {
int data;
public abstract int getData();
}
Class1.java:
public class Class1 extends Class0 {

private int data = 0;

@Override
public int getData() {
return data;
}
}
Class2.java:
public class Class2 extends Class0 {

private Class0 c;

public Class2(Class0 c) {
this.c = c;
}

@Override
public int getData() {
return ++c.data;
}
}
test.java:
public class test {

public static void main(String[] args) {

//实例化Class1
Class0 c1 = new Class1();
System.out.println(c1.getData());

//实例化Class2
Class2 c2 = new Class2(c1);
System.out.println(c2.getData());

}
}