Java设计模式之《装饰器模式》及应用场景

原创文章,转载请标注出处:Java设计模式之《装饰器模式》及应用场景html

1、概述

装饰器模式做用是针对目标方法进行加强,提供新的功能或者额外的功能。java

不一样于适配器模式和桥接模式,装饰器模式涉及的是单方,和代理模式相同,并且目标必须是抽象的。设计模式

而实际上,装饰器模式和代理模式的实现方式基本一致,只在目标的存在上有些差异,这个后面咱们具体讲述。ide

2、初步分析

上面提到了两点:测试

  • 涉及的是单方
  • 目标是抽象的

咱们来想一下,所谓单方主要指的是在整个装饰器模式中不存在双方调用,要解决的也不是双方调用的问题,而是解决单方提供对外服务的问题,这个单方在自行对外提供服务时,功能不足,或者咱们须要额外添加一些新功能,这时就可使用装饰器模式,来对这个单方进行加强。this

目标抽象的意思是由于咱们须要经过实现接口的方式来进行加强,所以目标必须抽象为接口。设计

3、实例

下面咱们用咱们生活中的一个例子来讲明,咱们用房子来做为目标:代理

房子接口:Housecode

/**
 * 目标接口:房子
 */
public interface House {
    void output();
}

具体的房子:DonghaoHousehtm

/**
 * 房子实现类
 */
public class DonghaoHouse implements House {
    @Override
    public void output() {
        System.out.println("这是董浩的房子");
    }
}

具体的房子:DongliangHouse

/**
 * 房子实现类
 */
public class DongliangHouse implements House {
    @Override
    public void output() {
        System.out.println("这是董量的房子");
    }
}

装饰器:Decorator

public class Decorator implements House {
    private House house;
    public Decorator(House house){
        this.house = house;
    }
    @Override
    public void output() {
        System.out.println("这是针对房子的前段装饰加强");
        house.output();
        System.out.println("这是针对房子的后段装饰加强");
    }
}

测试类:

public class Clienter {
    public static void main(String[] args) {
        House donghaoHouse = new DonghaoHouse();
        House decorator = new Decorator(donghaoHouse);
        decorator.output();
    }
}

执行结果为:

这是针对房子的前段装饰加强
这是董浩的房子
这是针对房子的后段装饰加强

4、解析

经过上面的例子咱们能够看出,除了测试类外,只剩下接口和实现类了,即便是装饰器类也是目标接口的一个字类,这更能说明单方的说法,模式中全部的类都属于目标方。至于目标是抽象的更是如此,只有目标是抽象的,才可使用装饰器模式来进行加强。

上面咱们说过装饰器模式与代理模式基本相同,只存在少量差异。

咱们须要从概念上了解代理和装饰的区别:

  • 代理是全权代理,目标根本不对外,所有由代理类来完成。
  • 装饰是加强,是辅助,目标仍然能够自行对外提供服务,装饰器只起加强做用。

上面两点提现到代码实现中是这样的:
代理模式

public class Proxy implements House {
    private House house;
    public Decorator(){
        this.house = new DonghaoHouse();
    }
    @Override
    public void output() {
        System.out.println("这是针对目标的前段加强");
        house.output();
        System.out.println("这是针对目标的后段加强");
    }
}

装饰模式

public class Decorator implements House {
    private House house;
    public Decorator(House house){
        this.house = house;
    }
    @Override
    public void output() {
        System.out.println("这是针对房子的前段装饰加强");
        house.output();
        System.out.println("这是针对房子的后段装饰加强");
    }
}

看出来了吗,装饰器中持有的目标实例是从构造器传入的,而代理中持有的目标实例是本身建立的。

那么这里又出现一个区别,代理模式和装饰器模式虽然都依赖于目标接口,可是代理针对的目标实现类是固定的,而装饰器模式能够随意指定,也就是说目标是能够自有扩展的。

5、使用场景

装饰器模式就是使用在对已有的目标功能存在不足,须要加强时,前提是目标存在抽象接口。

6、总结

咱们要明白代理模式和装饰器模式的区别,区分两者的使用场景,以下图:


同系列文章:

相关文章
相关标签/搜索