设计模式之装饰模式

装饰模式的通用类图:

看看我们的示例代码吧:

package 装饰模式;

//被装饰的类的抽象父类
public abstract class Component {
   public abstract void operation();
}
package 装饰模式;
 
//需要被装饰的具体类
public class Hourse extends Component {
 
    @Override
    public void operation() {
        System.out.println("这是一个普通的屋子。");
    }
}
 
package 装饰模式;
 
//抽象装饰类
public abstract class Decorator extends Component {
    //Component对象的引用
    private Component component;

    public Decorator(Component component) {
        this.component=component;
    }

    @Override
    public void operation() {
        this.component.operation();
    }
 
}
package 装饰模式;
 
//具体装饰类
public class DoorDecorator extends Decorator {
    public DoorDecorator(Component component){
        super(component);
    }
 
    @Override
    public void operation() {
        super.operation();
        System.out.println("装饰了屋子的门,屋子变漂亮了。");
    }
}
package 装饰模式;
 
//具体装饰类
public class FurnitureDecorator extends Decorator{
 
public FurnitureDecorator(Component component) {
super(component);
}
 
    @Override
    public void operation() {
        super.operation();
        System.out.println("装饰了屋子的家具,屋子变更漂亮了。");
    }
}
package 装饰模式;

//客户端
public class Client {
   public static void main(String[]args){
   Component hourse=new Hourse();
   hourse.operation();
   //给屋子的门进行装饰
   hourse=new DoorDecorator(hourse);
   hourse.operation();
   //给屋子的家具进行装饰
   hourse=new FurnitureDecorator(hourse);
   hourse.operation();
   }
}

输出:

这是一个普通的屋子。
这是一个普通的屋子。
装饰了屋子的门,屋子变漂亮了。
这是一个普通的屋子。
装饰了屋子的门,屋子变漂亮了。
装饰了屋子的家具,屋子变更漂亮了。

关于装饰模式的总结:

1、通过采用组合、而非继承的手法,Decorator模式实现了在运行时动态的扩展对象功能的能力,而且可以根据需要扩展多个功能。避免了单独使用继承带来的“灵活性差”和“多子类衍生问题”。
2、Component类在Decorator模式中充当抽象接口的角色,不应该去实现具体的行为。而且Decorator类对于
Component类应该透明——换言之Component类无需知道Decorator类,Decorator类是从外部来扩展Component类的功能。
3、Decorator类在接口上表现为is-a Component的继承关系,即Decorator类继承了Component类所具有的接口。但在实现上又表现为has-a Component的组合关系,即Decorator类又使用了另外一个Component类。我们可以使用一个或多个Decorator对象来“装饰”一个Component对象,且装饰后的对象仍然是一个Component
对象。我的理解是:当我们实例化一个Component对象后,要给这个对象扩展功能,这时我们把这个Component对象当作参数传给Decorator的子类的构造函数——也就是扩展方法的功能类。对于引用类型传参时,实际上只是传递对象的地址,也就是在原来的对象上扩展功能。
4、Decorator模式并非解决“多子类衍生的多继承”问题,Decorator模式应用的要点在于解决“主体类在多个方向上的扩展功能”——是为“装饰”的含义。Decorator是在运行时对功能进行组合。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • (转载)原文地址 在阎宏博士的《JAVA与模式》一书中开头是这样描述装饰(Decorator)模式的: 装饰模式又...
    zjk_00阅读 654评论 0 2
  • 装饰模式 定义 装饰模式又名包装(Wrapper)模式。装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一...
    晨鸣code阅读 1,403评论 0 0
  • 1 场景问题# 1.1 复杂的奖金计算## 考虑这样一个实际应用:就是如何实现灵活的奖金计算。 奖金计算是相对复杂...
    七寸知架构阅读 4,084评论 4 67
  • 装饰模式 动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类来的更为灵活。 Component...
    Keropok阅读 1,076评论 0 1
  • 蛰伏的冬天 爱在缓缓积累 思念在徐徐滋长 阴郁的心情 层层叠叠地交织 春分踏青 小草却说 我的身体过重了 于是 我...
    夜跑如风阅读 307评论 0 2