装饰者模式的基本组成是一个目标类和一个继承或实现目标类的装饰基类,目标类可以抽象出基类和多个子类,而装饰基类可以派生出多种具体的装饰类。
目标类中指定了核心行为,装饰基类继承于目标类,装饰基类及其子类通过重写这个行为方法,给目标类添加行为。装饰者模式特殊的一点是装饰类持有的引用,也就是依赖于目标类型,通过在行为方法中调用所依赖目标类型类的方法来实现行为的传承。
目标基类:
public abstract class Person {
abstract void wear();
}
目标实现类:
public class Man extends Person {
@Override
void wear() {
System.out.print("男人");
}
}
装饰基类:持有目标类的引用,本身继承于目标类,重写的行为方法是调用持有目标类的行为方法。
public abstract class DecoratorPerson extends Person {
Person person;
public DecoratorPerson(Person person) {
this.person = person;
}
@Override
void wear() {
person.wear();
}
}
装饰子类:继承于装饰基类,重写的行为方法是调用持有目标类的行为方法,加上自己添加的行为。
public class TShirtDecorator extends DecoratorPerson {
public TShirtDecorator(Person person) {
super(person);
}
@Override
void wear() {
super.wear();
System.out.print(" 穿T恤");
}
}
public class PantsDecorator extends DecoratorPerson {
public PantsDecorator(Person person) {
super(person);
}
@Override
void wear() {
super.wear();
System.out.print(" 穿长裤");
}
}
测试类:
public class Test {
public static void main(String[] args){
Man man = new Man();
TShirtDecorator tShirtDecorator = new TShirtDecorator(man);
tShirtDecorator.wear();
System.out.println();
new PantsDecorator(tShirtDecorator).wear();
System.out.println();
new UnderwearDecorator(new ShoesDecorator(new PantsDecorator(new Man()))).wear();
}
}
输出结果:
男人 穿T恤
男人 穿T恤 穿长裤
男人 穿长裤 穿鞋子 穿内裤
装饰者模式就像俄罗斯套娃,可以一层一层包装起来。
Java中的IO类即是使用装饰者模式实现的。
增强对象的三种方式及特点:
- 继承:只能固定增强某个类,同时固定增强该类的某些方法。适合知道对象的具体类型的场景。
- 装饰者模式:可以增强某个类(接口)及其子类(实现类),同时固定增强该类的某些方法,适合不知道对象的具体类型,只知道其父类或者所实现接口。
- 动态代理:可以动态增强某个类(接口),同时可以动态增强其中的方法。