gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 37 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章浅谈Java设计模式系列-装饰器模式由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

1、概述 。

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

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

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

2、初步分析 。

上面提到了两点:

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

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

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

3、实例 。

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

?
1
2
3
4
5
6
/**
  * 目标接口:房子
  */
public interface house {
  void output();
}

 具体的房子:donghaohouse 。

?
1
2
3
4
5
6
7
8
9
/**
  * 房子实现类
  */
public class donghaohouse implements house {
  @override
  public void output() {
   system.out.println( "这是董浩的房子" );
  }
}

具体的房子:donglianghouse 。

?
1
2
3
4
5
6
7
8
9
/**
  * 房子实现类
  */
public class donglianghouse implements house {
  @override
  public void output() {
   system.out.println( "这是董量的房子" );
  }
}

装饰器:decorator 。

?
1
2
3
4
5
6
7
8
9
10
11
12
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( "这是针对房子的后段装饰增强" );
  }
}

测试类:

?
1
2
3
4
5
6
7
public class clienter {
  public static void main(string[] args) {
   house donghaohouse = new donghaohouse();
   house decorator = new decorator(donghaohouse);
   decorator.output();
  }
}

 执行结果为:

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

 4、解析 。

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

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
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( "这是针对目标的后段增强" );
  }
}

 装饰模式 。

?
1
2
3
4
5
6
7
8
9
10
11
12
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、总结 。

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

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

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

原文链接:https://www.jianshu.com/p/45fc8a521a44 。

最后此篇关于浅谈Java设计模式系列-装饰器模式的文章就讲到这里了,如果你想了解更多关于浅谈Java设计模式系列-装饰器模式的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com