Java IO 装饰模式(Decorator)”总结

2024-05-27 10:32

本文主要是介绍Java IO 装饰模式(Decorator)”总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[color=red]JAVA里面用到的最重要的一个设计模式:“装饰模式(Decorator)”。几乎IO整个体系里面都用到这个模式[/color]。

• 装饰模式又名包装(Wrapper)模式。
• 装饰模式以对客户端透明的方式扩展[color=red]对象[/color]的功能,是继承关系的一个替代方案。【例如继承是用来扩展类的功能的,父类定义了一些方法,子类继承这些方法,那么子类的功能就扩展了。而这个模式是用来扩展对象的功能的,对象之间互相组合就能完成不同的功能。】
• 装饰模式以对客户透明的方式[color=red]动态[/color]的给一个对象附加上更多的责任。换言之,客户端并不会觉得对象在装饰前和装饰后有什么不同。
• [color=red]装饰模式可以在不创造更多子类的情况下,将对象的功能加以扩展[/color]。
• 装饰模式[color=red]把客户端的调用委派到被装饰类[/color]。装饰模式的关键在于这种扩展完全是透明
的。
• 装饰模式是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。


DataOutputStream dos = new DataOutputStream(new BufferedOutputStream(
new FileOutputStream("data.txt")));
• 装饰模式的角色:
–[color=red]抽象构件角色(Component)[/color]:给出一个抽象接口,以规范准备接收附加责任的对象。【例如以上代码里面的OutputStream是抽象构建角色】
–[color=red]具体构件角色(Concrete Component)[/color]:定义一个将要接收附加责任的类。【例如以上代码里面的FileOutputStream是一个具体构建角色】
–[color=red]装饰角色(Decorator)[/color]:[color=red]持有一个构件(Component)对象的引用[/color],并定义一个与抽象构件接口一致的接口。【例如以上代码里面的FilterOutputStream是装饰角色】
–[color=red]具体装饰角色(Concrete Decorator)[/color]:负责给构件对象“贴上”附加的责任。【例如以上代码里面的FilterOutputStream类的子类BufferedOutputStream是具体装饰角色】


• 装饰模式的特点:
–[color=red]装饰对象和真实对象有相同的接口。这样客户端对象就可以以和真实对象相同的方式和装饰对象交互[/color]。
–[color=red]装饰对象包含一个真实对象的引用(reference)[/color]
–装饰对象接收所有来自客户端的请求。它把这些请求转发给真实的对象。
–[color=red]装饰对象可以在转发这些请求以前或以后增加一些附加功能[/color]。这样就确保了在运行时,不用修改给定对象的结构就可以在外部增加附加的功能。在面向对象的设计中,通常是通过继承来实现对给定类的功能扩展。


下面来比较装饰模式和继承这两个的特点:
• [color=red]装饰模式[/color]:
–用来扩展特定对象的功能
–不需要子类
–动态
–运行时分配职责
–防止由于子类而导致的复杂和混乱
–更多的灵活性
–对于一个给定的对象,同时可能有不同的装饰对象,客户端可以通过它的需要选择合适的装饰对象发送消息。
• [color=red]继承[/color]:
–用来扩展一类对象的功能
–需要子类
–静态
–编译时分派职责
–导致很多子类产生
–缺乏灵活性


下面是代码实现的一个简单的装饰模式的示例,简单单足以说明问题:
package com.shengshiyuan.decorator;

/**
* 抽象构建角色
* 类: Component <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 12:31:27 PM
*/
public interface Component {

public void doSomething();
}

package com.shengshiyuan.decorator;

/**
* 具体构件角色
* 类: ConcreteComponent <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 12:31:40 PM
*/
public class ConcreteComponent implements Component {

public void doSomething() {
System.out.println("功能A");
}
}

package com.shengshiyuan.decorator;

/**
* 装饰角色
* 类: Decorator <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 12:20:54 PM
*/
public class Decorator implements Component {

private Component component;

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

public void doSomething() {
component.doSomething();
}
}

package com.shengshiyuan.decorator;

/**
* 具体装饰角色
* 类: ConcreteDecorator1 <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 12:28:48 PM
*/
public class ConcreteDecorator1 extends Decorator {

// 父类没有不带参数的构造方法,默认取找找不到,必须手动指明调用父类的哪个构造方法。
public ConcreteDecorator1(Component component) {
super(component);
}

@Override
public void doSomething() {
// 父类完成它的那个主要的功能,子类在下面增加它想要增加的功能。
super.doSomething();

// 子类完成它想要增加的功能。
this.doAnotherThing();
}

private void doAnotherThing() {
System.out.println("功能B");
}
}

package com.shengshiyuan.decorator;

/**
* 具体装饰角色
* 类: ConcreteDecorator2 <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 12:31:05 PM
*/
public class ConcreteDecorator2 extends Decorator {

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

@Override
public void doSomething() {
super.doSomething();

this.doAnotherThing();
}

private void doAnotherThing() {
System.out.println("功能C");
}
}

package com.shengshiyuan.decorator;

/**
* 测试类
* 类: Client <br>
* 描述: TODO <br>
* 作者: fangguanhong fangguanhong@163.com <br>
* 时间: Nov 18, 2013 2:07:43 PM
*/
public class Client {
public static void main(String[] args) {
// 节点流
Component component = new ConcreteComponent();
// 过滤流
Component component2 = new ConcreteDecorator1(component);
// 过滤流
Component component3 = new ConcreteDecorator2(component2);

component3.doSomething();

System.out.println("===============================================");

// 下面是整合之后的代码
Component comp = new ConcreteDecorator1(new ConcreteDecorator2(
new ConcreteComponent()));
comp.doSomething();
}
}

这篇关于Java IO 装饰模式(Decorator)”总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1007219

相关文章

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为