舒心、快乐,比什么都重要

装饰模式

装饰模式适用场景:

装饰者模式(Decorator Pattern),是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。
使用装饰者模式的时候需要注意一下几点内容:
1)装饰对象和真实对象有相同的接口。这样客户端对象就可以以和真实对象相同的方式和装饰对象交互。
2)装饰对象包含一个真实对象的引用。
3)装饰对象接受所有的来自客户端的请求,它把这些请求转发给真实的对象。
4)装饰对象可以在转发这些请求以前或以后增加一些附加功能。这样就确保了在运行时,不用修改给定对象的结构就可以在外部增加附加的功能。在面向对象的设计中,

通常是通过继承来实现对给定类的功能扩展。然而,装饰者模式,不需要子类可以在应用程序运行时,动态扩展功能,更加方便、灵活。

适用装饰者模式场合:
1.当我们需要为某个现有的对象,动态的增加一个新的功能或职责时,可以考虑使用装饰模式。
2.当某个对象的职责经常发生变化或者经常需要动态的增加职责,避免为了适应这样的变化,而增加继承子类扩展的方式,因为这种方式会造成子类膨胀的速度过快,难以控制。

装饰模式代码

组件抽象对象,定义了这个组件的一些方法

public abstract class Component {
    public abstract void operate();
}

组件对象实现实例

嗯。。。相当于你把这个组件继承了过来,实现了里面的方法。

public class ConcreteComponent extends Component {
    @Override
    public void operate() {
        Log.v("Component","ConcreteComponent");
    }
}

那么下面我要去扩展这个对象,给他增加方法怎么办呢

有人说我在ConcreteComponent里面改不就行了,然后你还得改Component

装饰模式就是在不修改原有代码的基础上去动态的扩展咱们的组件

下面定义一个装饰者抽象

这个装饰者继承自组件,并且持有原始抽象组件引用

public abstract class Decorator extends Component {
    private Component component;

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

    @Override
    public void operate() {
        component.operate();
    }
}

然后假如你想加入一个方法A给Component

public class DecoratorA extends Decorator {

    public DecoratorA(Component component){
        super(component);
    }

    @Override
    public void operate() {
        super.operate();
        operateA();
    }

    public void operateA(){
        Log.v("Decorator","DecoratorA");
    }
}

这样你就完成了包装类A,BCD等等类似

使用方法

Component component = new ConcreteComponent();
        Decorator decoratorA = new DecoratorA(component);
        decoratorA.operate();
        Decorator decoratorB = new DecoratorB(component);
        decoratorB.operate();

至此这就是装饰模式的模板方法例子

 

posted @ 2016-12-13 17:43  Arcturis  阅读(164)  评论(0编辑  收藏  举报