当前位置: 首页 > 编程笔记 >

浅谈Java设计模式系列-装饰器模式

蒙华翰
2023-03-14
本文向大家介绍浅谈Java设计模式系列-装饰器模式,包括了浅谈Java设计模式系列-装饰器模式的使用技巧和注意事项,需要的朋友参考一下

一、概述

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

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

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

二、初步分析

上面提到了两点:

  1. 涉及的是单方
  2. 目标是抽象的

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

目标抽象的意思是因为我们需要通过实现接口的方式来进行增强,因此目标必须抽象为接口。

三、实例

下面我们用我们生活中的一个例子来说明,我们用房子来作为目标:
房子接口:House

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

 具体的房子:DonghaoHouse

/**
 * 房子实现类
 */
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();
 }
}

 执行结果为:

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

 四、解析

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

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

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

  1. 代理是全权代理,目标根本不对外,全部由代理类来完成。
  2. 装饰是增强,是辅助,目标仍然可以自行对外提供服务,装饰器只起增强作用。

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

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("这是针对房子的后段装饰增强");
 }
}

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

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

五、使用场景

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

六、总结

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

以上所述是小编给大家介绍的Java设计模式系列-装饰器模式详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!

 类似资料:
  • 本文向大家介绍浅谈JAVA设计模式之享元模式,包括了浅谈JAVA设计模式之享元模式的使用技巧和注意事项,需要的朋友参考一下 享元模式(Flyweight Pattern)主要用于减少创建对象的数量,以减少内存占用和提高性能。这种类型的设计模式属于结构型模式,它提供了减少对象数量从而改善应用所需的对象结构的方式。 享元模式尝试重用现有的同类对象,如果未找到匹配的对象,则创建新对象。我们将通过创建 5

  • 装饰(Decorator) Intent 为对象动态添加功能。 Class Diagram 装饰者(Decorator)和具体组件(ConcreteComponent)都继承自组件(Component),具体组件的方法实现不需要依赖于其它对象,而装饰者组合了一个组件,这样它可以装饰其它装饰者或者具体组件。所谓装饰,就是把这个装饰者套在被装饰者之上,从而动态扩展被装饰者的功能。装饰者的方法有一部分是

  • 本文向大家介绍java设计模式学习之装饰模式,包括了java设计模式学习之装饰模式的使用技巧和注意事项,需要的朋友参考一下 装饰模式:动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更加灵活。 优点:装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的一个替代模式,装饰模式可以动态扩展一个实现类的功能。 缺点:多层装饰比较复杂。 实例:给一个人配置穿衣 1:代码结构图

  • 当我回顾了“decorator”设计模式的大量示例时,我刚刚想到了一些示例,这些示例主要是关于更改总是返回字符串的方法,或者像cost()这样聚合数字的方法。 这真的是装饰器设计模式的唯一用法吗? 我只知道它用于Java IO API。 但我想有其他的东西,打印一个文本。一些真实的东西。我找了那么多,却找不到合适的样品。

  • 介绍 装饰者提供比继承更有弹性的替代方案。 装饰者用用于包装同接口的对象,不仅允许你向方法添加行为,而且还可以将方法设置成原始对象调用(例如装饰者的构造函数)。 装饰者用于通过重载方法的形式添加新功能,该模式可以在被装饰者前面或者后面加上自己的行为以达到特定的目的。 正文 那么装饰者模式有什么好处呢?前面说了,装饰者是一种实现继承的替代方案。当脚本运行时,在子类中增加行为会影响原有类所有的实例,而

  • 本文向大家介绍Java设计模式之装饰模式(Decorator模式)介绍,包括了Java设计模式之装饰模式(Decorator模式)介绍的使用技巧和注意事项,需要的朋友参考一下 Decorator常被翻译成"装饰",我觉得翻译成"油漆工"更形象点,油漆工(decorator)是用来刷油漆的,那么被刷油漆的对象我们称decoratee。这两种实体在Decorator模式中是必须的。 Decorator