装饰器模式
动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式比生成子类更为灵活。
装饰器的优点
- 装饰类和被装饰类可以独立发展,而不会相互耦合。
- 装饰器模式是继承关系的一个替代方案。
- 装饰器模式可以动态地扩展一个实现类的功能。
装饰器的缺点
- 多层装饰是比较复杂的。
- 装饰器的使用场景。
- 需要扩展一个类的功能,或给一个类增加附加功能。
- 需要动态地给一个对象增加功能,这些功能可以在动态地撤销。
- 需要为一批类进行改装或加装功能。
装饰器模式是对继承的有力补充。单纯使用继承时,在一些情况下就会增加很多子类,而且灵活性差,维护不容易。装饰器模式可以替代继承,解决类膨胀的问题,如Java基础类库中的输入输出流相关的类大量的使用了装饰模式。
示例代码
- 汽车接口
public interface Car {
// 车的装配
public void show();
}
- 汽车实现类
public class Benz implements Car {
@Override
public void show() {
System.out.println("奔驰车的默认颜色是黑色");
}
}
- 汽车装饰抽象类
public abstract class CarDecorator implements Car{
private Car car = null;
public CarDecorator(Car car){
this.car = car;
}
@Override
public void show() {
this.car.show();
}
}
- 汽车装饰具体类
public class ConcreteCarDecorator extends CarDecorator {
public ConcreteCarDecorator(Car car) {
super(car);
}
// 给车彩绘
private void print(){
System.out.println("在车尾绘制新手字样,颜色是紫色霞光");
}
// 给车安装GPS设备
private void setGps(){
System.out.println("安装GPS定位导航系统");
}
// 重写show()方法
public void show(){
super.show();
this.print();
this.setGps();
}
}
- 主逻辑
public class ClientDemo {
public static void main(String[] args) {
Car car = new Benz();
// 对车进行装饰
CarDecorator cd = new ConcreteCarDecorator(car);
cd.show();
}
}