`

设计模式之装饰者模式Decorator

 
阅读更多
装饰者模式
职责
  • 动态的为一个对象增加新的功能装饰模式是一种用于代替继承的技术,无须通过类继承增加子类就能扩展对象的新功能。使用对象的关联关系代替继承关系,更加灵活,同时避免类型体系的快速膨胀 
  • 装饰者模式隐含的是通过一条条装饰链去实现具体对象,每一条装饰链都始于一个Componet对象,每个装饰者对象后面紧跟着另一个装饰者对象,而对象链终于ConcreteComponet对象。
  • 关键字:提高内聚性,面向接口编程,封装变化使用组合,OCP

 

结构
  • Component抽象构建角色:真实对象和封装对象有相同的接口,这样客户端对象能够以与真实对象相同的方式同饰对象交互(Component定义ConcreteComponent和Decorator类要实现的方法,简单来说如果一个类继承于该类就具有装饰或被装饰能力。 
  • ConcreteComponent具体构建角色(真实对象):IO流中的FileInputStream、FileOutputStream
  • Decorator装饰角色:持有一个抽象构建的引用,装饰对象接受所有客户端的请求,并把这些请求转发给真实对象。这样,就能在真实对象调用前后增加新的功能(Decorator具有特定装饰功能的类,用来装饰ConcreteComponent类。)
  • ConcreteDecorator具体装饰角色:负责给构建对象增加新的责任 

结构图

 

 代码

/**
 * 抽象组件
 */
public interface ICar {
    void move();
}

/**
 * 真实对象的类,具体构建角色
 */
class Car implements ICar{
    @Override
    public void move() {
        System.out.println("陆地上跑");
    }
}

/**
 * Decorator装饰角色
 */
class SupperCar implements ICar{
    private ICar car;

    public SupperCar(ICar car) {
        this.car = car;
    }

    @Override
    public void move() {
        car.move();
    }
}

//ConcreteDecorator具体装饰角色
class FlyCar extends SupperCar{

    public FlyCar(ICar car) {
        super(car);
    }

    public void fly(){
        System.out.println("飞到天上去!");
    }

    @Override
    public void move(){
        super.move();
        fly();
    }
}

//ConcreteDecorator具体装饰角色
class AutoCar extends SupperCar{

    public AutoCar(ICar car) {
        super(car);
    }

    public void autoMove(){
        System.out.println("自动");
    }

    @Override
    public void move(){
        super.move();
        autoMove();
    }
}

class WaterCar extends SupperCar{

    public WaterCar(ICar car) {
        super(car);
    }

    public void water(){
        System.out.println("新功能,在水里游");
    }

    @Override
    public void move(){
        super.move();
        water();
    }
}

 

public class Client {

    public static void main(String[] args){

        Car car = new Car();
        car.move();

        System.out.println("---------增加新的功能飞行---------");
        FlyCar flyCar = new FlyCar(car);
        flyCar.move();

        System.out.println("---------增加新的功能,自动-------");
        WaterCar waterCar = new WaterCar(car);
        waterCar.move();

        System.out.println("-----增加两个功能:飞行+水里游-----");
        flyCar = new FlyCar(waterCar);
        flyCar.move();

    }
}

 

 

IO流实现细节:
  • Component抽象构建角色:我们知道Java所有的IO都是基于InputStream、OutputStream、Reader、Writer这四个抽象类,因此IO流中的InputStream、OutputStream、Reader、Writer起到的作用就是抽象构建这个角色
  • ConcreteComponent具体构建角色:IO流中的FileInputStream、FileOutputStream
  • Decorator装饰角色:持有一个抽象构建的引用,IO流中的FilterInputStream、FilterOutputStream
  • ConcreteDecorator具体装设角色:负责给构件对象增加新的责任。IO流中的BufferedOutputStream、BufferedInputStream等 

   Reader r = new BufferedReader(new InputStreamReader(new FileInputStream(new File("d:/a.txt"))));

       FileInputStream真实角色

 

       InputStreamReader、BufferedReader 两个都是装饰者

 

 场景


  • IO中输入流和输出流的设计
  • Servlet API中提供了一个request 对象的 Decorator设计模式的默认实现类 HttpServletRequestWrapper
  • HttpServletRequestWrapper类,增强了request对象的功能
  • Structs2中,request,response,session对象的处理 
总结:
装饰者模式(Decorator)也叫包装器模式(Wrapper)。装饰者模式降低系统的耦合度,可以动态的增加或删除对象的职责,并使得需要装饰的具体构建类和具体装饰类可以单独变化,以增加新的具体构建类和具体装饰类
 
优点:
  • 扩展对象的功能,比继承灵活,不会导致类个数急剧增加
  • 可以对一个对象进行多次装饰,创造出不同行为的组合,得到功能更加强大的对象
  • 可以对一个对象进行多次装饰,创造出不同行为的组合,得到功能更加强大的对象
  • 具体构建类和具体装饰类可以独立变化,用户可以根据需要自己增加新的具体构建子类的具体装饰子类
 
装饰者模式和桥接模式的区别
 
两个模式都是为了解决过多子类对象问题,但他们的诱因不一样。桥接模式是对象自身现有机制沿着多个维度变化,是既有部分不稳定。装饰者模式是为了增加新的功能 
  • 大小: 59.3 KB
分享到:
评论

相关推荐

    C#设计模式之Decorator 装饰模式

    装饰模式(Decorator Pattern)是设计模式中的一种结构型模式,它在不改变原有对象的基础上,通过添加额外的职责来扩展对象的功能。在C#中,装饰模式尤其适用于那些需要动态地增加或减少对象功能的情况,避免了使用...

    设计模式之 Decorator模式和代码实现

    【Decorator模式】是一种设计模式,它允许在运行时动态地给对象添加新的责任或功能,而不必通过子类化的方式。在上述的奇幻RPG游戏中,Decorator模式被用来实现武器的锻造过程,尤其是武器镶嵌宝石的功能。这个过程...

    设计模式之装饰模式(Decorator Pattern)

    装饰模式(Decorator Pattern)是一种结构型设计模式,它在不改变原有对象的基础上,通过包裹一个对象并为其添加新的行为或责任,实现对对象功能的扩展。这种模式在软件开发中非常常见,尤其当需要在运行时动态改变...

    [结构型模式] head first 设计模式之装饰者模式(decorator)

    装饰者模式(Decorator Pattern)是结构型设计模式之一,它允许动态地给一个对象添加新的功能,而无需修改其原有代码。这个模式的核心思想是通过将对象封装在一个包装器(Decorator)中来扩展其行为,而包装器和原始...

    设计模式之装饰者(Decorator)

    装饰者模式是软件设计中的一种行为模式,它允许在运行时动态地给对象添加新的行为或职责,而无需改变对象的原始类。这种模式在不违反开闭原则的前提下,提供了扩展对象功能的能力,使得系统更加灵活,易于维护。 在...

    c++-设计模式之装饰模式(Decorator)

    装饰模式(Decorator Pattern)是一种结构型设计模式,允许在不改变对象接口的情况下,动态地为对象添加额外的职责或功能。装饰模式通常用于需要扩展对象功能而又不希望使用子类化的场景。 装饰模式的组成 组件接口...

    设计模式--装饰者模式java例子

    装饰者模式是软件设计模式中的一种结构型模式,它的主要目的是动态地给对象添加新的功能,而无需修改原有代码。在Java中,装饰者模式通常通过继承和组合来实现,它提供了一种比继承更灵活的方式来扩展对象的功能。...

    设计模式之装饰者模式,内含可运行代码

    总的来说,装饰者模式是一种强大的设计模式,它提供了一种在运行时动态调整对象行为的方法,使得代码更具灵活性和可扩展性。通过理解和熟练运用装饰者模式,我们可以更好地应对软件需求的变化,提高代码的可维护性和...

    设计模式之Decorator

    《设计模式之Decorator》 设计模式是软件工程中的一种最佳实践,它是在特定场景下解决常见问题的经验总结。Decorator模式是一种结构型设计模式,它的主要作用是为对象添加额外的功能,而无需修改对象的源代码。...

    Java设计模式之-Decorator装饰模式

    Decorator模式,也称为装饰模式,是设计模式中的一个重要组成部分,它在不改变原有对象接口的前提下,动态地给对象添加新的功能,从而扩展了对象的能力。这篇博客()将深入探讨这个模式的细节。 装饰模式的核心...

    装饰者模式——Decorator

    装饰者模式(Decorator)是一种设计模式,用于在运行时动态地给对象添加额外的责任或功能。它是结构型设计模式的一种,能将行为的增加与对象的创建分离,使得我们可以独立地扩展对象的功能。 在Java或其他面向对象...

    java设计模式之装饰者模式代码

    装饰者模式是面向对象设计模式的一种,主要用于动态地给一个对象添加一些额外的职责,而不会改变该对象的类。这种模式允许我们独立于对象的类来扩展对象的功能,为对象提供新的行为,同时保持了代码的可读性和可维护...

    设计模式C++学习之装饰模式(Decorator)

    装饰模式(Decorator)是软件设计领域中一种非常实用的结构型设计模式,它允许我们向一个对象添加新的行为或责任,而无需修改该对象的源代码。在C++编程语言中,装饰模式常用于动态地扩展类的功能,使得类的行为在...

    设计模式 t07Decorator

    在给定的“设计模式 t07Decorator”主题中,我们聚焦于装饰者模式(Decorator Pattern)。装饰者模式是一种结构型设计模式,它允许我们在运行时给对象添加新的行为或职责,而无需修改其原有代码。这种模式遵循开闭...

    大话西游之设计模式_从猴王学艺看Decorator 配套代码

    "Decorator"设计模式,又称装饰者模式,是面向对象设计中的一种重要模式。它允许我们动态地给一个对象添加新的行为或职责,而无需修改该对象的类。这个模式的核心思想是封装额外的功能,使得原有对象的功能得到扩展...

    Head First 设计模式 (三) 装饰者模式(decorator pattern) C++实现

    装饰者模式(Decorator Pattern)是一种结构型设计模式,它允许我们向对象添加新的行为或职责,而无需修改对象的原始代码。在C++中实现装饰者模式,可以让我们灵活地扩展对象的功能,同时保持代码的可读性和可维护性...

Global site tag (gtag.js) - Google Analytics