23种设计模式(6)-装饰者模式

简介: 23种设计模式(6)-装饰者模式

定义:

   在不必改变原类文件和原类使用的继承的情况下,动态地扩展一个对象的功能。


   它是通过创建一个包装对象,也就是用装饰来包裹真实的对象来实现。


角色:


   抽象构件角色(Project):给出一个接口,以规范准备接收附加责任的对象。


   具体构件角色(Employe):定义一个将要接收附加责任的类。


   装饰角色(Manager):持有一个构件对象的实例,并定义一个与抽象构件接口一致的接口。


  具体装饰角色(ManagerA、ManagerB):负责给构件对象“贴上”附加的责任。


示例:


公共接口:

public interface Person {  
    void eat();  
}


被装饰对象:

public class OldPerson implements Person {  
    @Override  
    public void eat() {  
        System.out.println("吃饭");  
    }  
}


装饰对象:

public class NewPerson implements Person {  
    private OldPerson p;  
    NewPerson(OldPerson p) {  
        this.p = p;  
    }  
    @Override  
    public void eat() {  
        System.out.println("生火");  
        System.out.println("做饭");  
        p.eat();  
        System.out.println("刷碗");   
    }  
}


测试:


public class PersonDemo {  
    public static void main(String[] args) {  
        OldPerson old = new OldPerson();  
        //old.eat(); 
        NewPerson np = new NewPerson(old);  
        np.eat();  
    }  
}

     

通过例子可以看到,没有改变原来的OldPerson类,同时也没有定义他的子类而实现了Person的扩展,这就是装饰者模式的作用。


优点:


       1,使用装饰者模式比使用继承更加灵活,因为它选择通过一种动态的方式来扩展一个对象的功能,在运行时可以选择不同的装饰器,从而实现不同的行为。


       2,通过使用不同的具体装饰类以及这些装饰类的排列组合,可以创造出很多不同行为的组合。可以使用多个具体装饰类来装饰同一对象,得到功能更为强大的对象。


       3,具体构件类与具体装饰类可以独立变化,他能是低耦合的。用户可以根据需要来增加新的具体构件类和具体装饰类,在使用时再对其进行各种组合,原有代码无须改变,符合“开闭原则”。

 

缺点:


       1,会产生很多的小对象,增加了系统的复杂性


       2,这种比继承更加灵活机动的特性,也同时意味着装饰模式比继承更加易于出错,排错也很困难,对于多次装饰的对象,调试时寻找错误可能需要逐级排查,较为烦琐。

 

装饰者与适配者模式的区别:


  1,适配器模式主要用来兼容那些不能在一起工作的类,使他们转化为可以兼容目标接口,虽然也可以实现和装饰者一样的增加新职责,但目的不在此。


       装饰者模式主要是给被装饰者增加新职责的。


  2,适配器模式是用新接口来调用原接口,原接口对新系统是不可见或者说不可用的。


       装饰者模式原封不动的使用原接口,系统对装饰的对象也通过原接口来完成使用。


  3,适配器是知道被适配者的详细情况的(就是那个类或那个接口)。


       装饰者只知道其接口是什么,至于其具体类型(是基类还是其他派生类)只有在运行期间才知道。

 

装饰者和继承的区别:


继承:


  优点:代码结构清晰,而且实现简单


  缺点:对于每一个的需要增强的类都要创建具体的子类来帮助其增强,这样会导致继承体系过于庞大。


装饰者:


  优点:内部可以通过多态技术对多个需要增强的类进行增强


      缺点:需要内部通过多态技术维护需要增强的类的实例。进而使得代码稍微复杂。


使用场景:


       1,需要扩展一个类的功能,或给一个类添加附加职责。


       2,需要动态的给一个对象添加功能,这些功能可能不明确或者暂时的,可以随时很方便的动态撤销掉。


       3,需要增加由一些基本功能的排列组合而产生的非常大量的功能,从而使继承关系变的不现实。


       4. 当不能采用生成子类的方法进行扩充时。一种情况是,可能有大量独立的扩展,为支持每一种组合将产生大量的子类,使得子类数目呈爆炸性增长。另一种情况可能是因为类定义被隐藏,或类定义不能用于生成子类。

 

Java知音公众号推送一些Java必备的知识,让您在闲暇之余巩固一下自己的知识体系 ,扩充一下自己的知识面。快利用琐碎时间给自己充

相关文章
|
设计模式 Java
Java设计模式【十】:装饰者模式
Java设计模式【十】:装饰者模式
157 0
|
7月前
|
设计模式 缓存 安全
【设计模式】【结构型模式】装饰者模式(Decorator)
一、入门 什么是装饰者模式? 装饰者模式(Decorator Pattern)是 Java 中常用的结构型设计模式,它能在不修改原有对象结构的前提下,动态地为对象添加额外的职责。 为什么要装饰者模式?
175 8
|
9月前
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。
|
设计模式 Java Kotlin
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
148 2
|
设计模式 Java Kotlin
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
|
设计模式 Java Kotlin
Kotlin - 改良设计模式 - 装饰者模式
Kotlin - 改良设计模式 - 装饰者模式
98 4
|
设计模式 Java Kotlin
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
|
设计模式 Java Kotlin
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
Kotlin教程笔记(56) - 改良设计模式 - 装饰者模式
103 0
|
设计模式 Java Kotlin
Kotlin 学习笔记- 改良设计模式 - 装饰者模式
Kotlin 学习笔记- 改良设计模式 - 装饰者模式
122 0

热门文章

最新文章