- 浏览: 324408 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (254)
- java (178)
- tomcat (6)
- 邮件 (1)
- smtp (1)
- Linux (2)
- 编码 (2)
- 导入工程 (1)
- Specification Level (1)
- hibernate (10)
- 字段类型 (1)
- 字段类型匹配 (1)
- 数据库 (3)
- sql (9)
- struts2 (8)
- 类型转换 (2)
- java,MyEclipse,SVN (1)
- Myecplise (4)
- 输入校验 (1)
- JFrame (2)
- Oracle (8)
- google (1)
- Swing (3)
- Fusioncharts (1)
- 找工作 (0)
- js (4)
- jsp (11)
- displaytag (1)
- spring (8)
- 工作 (1)
- String (1)
- 算法 (2)
- IO (1)
- xml (3)
- 设计模式 (1)
- UML (1)
- 文档 (1)
- ajax (1)
- 日常 (7)
- sql server (1)
- mysql (3)
- git (1)
- Maven (1)
- mongodb (1)
- postman (1)
最新评论
JAVA里面用到的最重要的一个设计模式:“装饰模式(Decorator)”。几乎IO整个体系里面都用到这个模式。
• 装饰模式又名包装(Wrapper)模式。
• 装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案。【例如继承是用来扩展类的功能的,父类定义了一些方法,子类继承这些方法,那么子类的功能就扩展了。而这个模式是用来扩展对象的功能的,对象之间互相组合就能完成不同的功能。】
• 装饰模式以对客户透明的方式动态的给一个对象附加上更多的责任。换言之,客户端并不会觉得对象在装饰前和装饰后有什么不同。
• 装饰模式可以在不创造更多子类的情况下,将对象的功能加以扩展。
• 装饰模式把客户端的调用委派到被装饰类。装饰模式的关键在于这种扩展完全是透明
的。
• 装饰模式是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。
DataOutputStream dos = new DataOutputStream(new BufferedOutputStream(
new FileOutputStream("data.txt")));
• 装饰模式的角色:
–抽象构件角色(Component):给出一个抽象接口,以规范准备接收附加责任的对象。【例如以上代码里面的OutputStream是抽象构建角色】
–具体构件角色(Concrete Component):定义一个将要接收附加责任的类。【例如以上代码里面的FileOutputStream是一个具体构建角色】
–装饰角色(Decorator):持有一个构件(Component)对象的引用,并定义一个与抽象构件接口一致的接口。【例如以上代码里面的FilterOutputStream是装饰角色】
–具体装饰角色(Concrete Decorator):负责给构件对象“贴上”附加的责任。【例如以上代码里面的FilterOutputStream类的子类BufferedOutputStream是具体装饰角色】
• 装饰模式的特点:
–装饰对象和真实对象有相同的接口。这样客户端对象就可以以和真实对象相同的方式和装饰对象交互。
–装饰对象包含一个真实对象的引用(reference)
–装饰对象接收所有来自客户端的请求。它把这些请求转发给真实的对象。
–装饰对象可以在转发这些请求以前或以后增加一些附加功能。这样就确保了在运行时,不用修改给定对象的结构就可以在外部增加附加的功能。在面向对象的设计中,通常是通过继承来实现对给定类的功能扩展。
下面来比较装饰模式和继承这两个的特点:
• 装饰模式:
–用来扩展特定对象的功能
–不需要子类
–动态
–运行时分配职责
–防止由于子类而导致的复杂和混乱
–更多的灵活性
–对于一个给定的对象,同时可能有不同的装饰对象,客户端可以通过它的需要选择合适的装饰对象发送消息。
• 继承:
–用来扩展一类对象的功能
–需要子类
–静态
–编译时分派职责
–导致很多子类产生
–缺乏灵活性
下面是代码实现的一个简单的装饰模式的示例,简单单足以说明问题:
• 装饰模式又名包装(Wrapper)模式。
• 装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案。【例如继承是用来扩展类的功能的,父类定义了一些方法,子类继承这些方法,那么子类的功能就扩展了。而这个模式是用来扩展对象的功能的,对象之间互相组合就能完成不同的功能。】
• 装饰模式以对客户透明的方式动态的给一个对象附加上更多的责任。换言之,客户端并不会觉得对象在装饰前和装饰后有什么不同。
• 装饰模式可以在不创造更多子类的情况下,将对象的功能加以扩展。
• 装饰模式把客户端的调用委派到被装饰类。装饰模式的关键在于这种扩展完全是透明
的。
• 装饰模式是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。
DataOutputStream dos = new DataOutputStream(new BufferedOutputStream(
new FileOutputStream("data.txt")));
• 装饰模式的角色:
–抽象构件角色(Component):给出一个抽象接口,以规范准备接收附加责任的对象。【例如以上代码里面的OutputStream是抽象构建角色】
–具体构件角色(Concrete Component):定义一个将要接收附加责任的类。【例如以上代码里面的FileOutputStream是一个具体构建角色】
–装饰角色(Decorator):持有一个构件(Component)对象的引用,并定义一个与抽象构件接口一致的接口。【例如以上代码里面的FilterOutputStream是装饰角色】
–具体装饰角色(Concrete Decorator):负责给构件对象“贴上”附加的责任。【例如以上代码里面的FilterOutputStream类的子类BufferedOutputStream是具体装饰角色】
• 装饰模式的特点:
–装饰对象和真实对象有相同的接口。这样客户端对象就可以以和真实对象相同的方式和装饰对象交互。
–装饰对象包含一个真实对象的引用(reference)
–装饰对象接收所有来自客户端的请求。它把这些请求转发给真实的对象。
–装饰对象可以在转发这些请求以前或以后增加一些附加功能。这样就确保了在运行时,不用修改给定对象的结构就可以在外部增加附加的功能。在面向对象的设计中,通常是通过继承来实现对给定类的功能扩展。
下面来比较装饰模式和继承这两个的特点:
• 装饰模式:
–用来扩展特定对象的功能
–不需要子类
–动态
–运行时分配职责
–防止由于子类而导致的复杂和混乱
–更多的灵活性
–对于一个给定的对象,同时可能有不同的装饰对象,客户端可以通过它的需要选择合适的装饰对象发送消息。
• 继承:
–用来扩展一类对象的功能
–需要子类
–静态
–编译时分派职责
–导致很多子类产生
–缺乏灵活性
下面是代码实现的一个简单的装饰模式的示例,简单单足以说明问题:
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(); } }
发表评论
-
领域精通涉及技术点(不分先后)
2017-12-20 19:35 620Java8 netty jvm kafaka消息队列 上传下载 ... -
计算机各种单位讲解及换算
2017-12-13 13:54 1642我还听过有UK的 一、最小单位:位(bit,缩写为b) 在原 ... -
JAVA字符串格式化-String.format()和MessageFormat的使用
2017-12-05 10:39 1447String.format()常规类型的格式化 Stri ... -
eclipse启动项目常见问题
2017-11-16 17:46 1184今儿遇到了个问题,ecli ... -
字符编码笔记:ASCII,Unicode和UTF-8
2017-10-23 16:37 458讲的太牛逼了: http://ww ... -
emoji简单讲解
2017-10-23 15:17 973emoji处理方式大起底 http://blog.csdn.n ... -
BigDecimal讲解
2017-10-12 15:58 445BigDecimal 由任意精度的整数非标度值 和 32 位的 ... -
eclips 控制台console上不打印信息
2017-09-06 21:53 5811、进windows菜单 -> show view -& ... -
详解RequestMappingHandlerMapping和RequestMappingHandlerAdapter
2017-08-29 17:08 2981http://donald-draper.iteye.com/ ... -
用@ExceptionHandler 来进行切面异常处理
2017-08-29 11:47 2311有时候我们想处理某个类里Controller中抛出的异常怎么搞 ... -
Spring 注解@Component、@Repository、@Service、@Controller区别
2017-08-28 15:27 1017spring 2.5 中除了提供 @Com ... -
线程的一点小总结
2017-08-23 20:36 709java中main方法启动的是一个进程还是一个线程? 答:是一 ... -
线程池
2017-08-23 17:35 522诸如Web 服务器、数据库 ... -
Class源码大概讲解
2017-08-23 16:47 512http://blog.csdn.net/a327369238 ... -
Spring 事务相关
2017-08-14 12:10 476Transactionz注解的readOnly ... -
把时间当做朋友-前言
2017-08-13 20:47 407要管理的不是时间,而是自己。人们生活在同一个世界,却又各自 ... -
单例里面的方法讲解
2017-08-11 14:55 490spring里的controller是单例的。系统针对每个co ... -
eclipse拷贝出来的项目名称还是原来的
2017-07-26 16:46 1082需要修改的有如下几个地方: 1、pom.xml里面打包的名字一 ... -
自定义hibernate方言,新增自定义函数
2017-06-27 10:47 880按位与运算(&)在许多数据库中都是支持的,遗憾的是,H ... -
http请求参数:header body paramter三种参数区别、联系
2017-06-19 10:46 489112345
相关推荐
装饰模式(Decorator Pattern)是设计模式中的一种结构型模式,它允许在运行时给对象添加新的行为或职责,而无需改变对象的类。在Java中,装饰模式通常通过继承和组合来实现,使得代码具有更好的扩展性和灵活性。...
总结起来,Java的IO体系结构利用Decorator模式实现了高度的灵活性和可扩展性。通过组合不同类型的装饰者,我们可以构建出满足各种需求的输入输出流,而不必创建大量的子类。这种设计使得Java的IO库在功能强大且多样...
总结起来,Java的IO体系通过Decorator模式实现了输入输出流功能的动态扩展,使得在运行时可以灵活组合不同的流特性,而不需要预先创建大量预定义的子类。理解Decorator模式及其在Java IO中的应用,对于深入掌握Java ...
Java的IO库是一个复杂而强大的系统,其设计思想和实现方式体现了多种设计模式,包括Decorator(装饰者)模式和Adapter(适配器)模式。本文将深入探讨这两个模式在Java/IO中的应用,并通过实例解释它们如何使得Java...
在Java中,装饰模式的一个经典例子是`java.io`包中的流类。例如,`FileInputStream`是具体组件,`BufferedInputStream`和`DataInputStream`则是具体装饰者,它们分别增加了缓冲和数据转换的功能,但保持了对原始输入...
1. 装饰器模式(Decorator):Java IO系统中广泛使用该模式,通过装饰器模式来扩展IO流的功能。 五、举例说明: 1. Java IO的类和接口:通过查看Java IO包下的类和接口,可以了解到Java在IO上的丰富支持,包括各种...
Java IO的设计采用了Decorator模式,使得在不修改原有类的基础上,能够动态地增加新功能。 Decorator模式是一种设计模式,它允许我们在运行时向对象添加新的行为或责任,而无需修改该对象的源代码。在Java IO中,...
在实际应用中,装饰者模式常常用于对IO流的处理,如BufferedInputStream和DataOutputStream等,它们都继承自InputStream和OutputStream,通过组合的方式增加了缓冲和数据转换等功能。此外,还可以应用于UI组件的扩展...
总结起来,Decorator设计模式在Java IO流中的运用,赋予了流类更多的功能,使得我们能够根据需求灵活组合不同的流类,实现强大的数据处理能力。通过深入学习和理解这些模式,开发者可以更好地优化代码,提高程序的...
它提供了一个面向对象的API,并且在Java IO库中采用了装饰器模式(Decorator Pattern)来减少类的数量,使得整个框架既灵活又易于扩展。Java的IO系统主要由两大块组成: 1. **堵塞型IO (Blocking IO)**:位于`java.io...
例如,`java.io`包中的许多流类(如BufferedInputStream和PrintStream)就是装饰模式的实例,它们通过装饰基本的InputStream和OutputStream来增强功能,如缓冲和格式化输出。 总的来说,装饰模式是一种灵活的设计...
Java的IO模型采用了装饰者模式(Decorator Pattern),这使得开发者可以根据具体需求动态地组合不同的流类来构建所需的IO功能。例如,如果需要一个具有缓冲功能的文件输入流,可以通过组合`FileInputStream`和`...
结构型模式如适配器(Adapter)、装饰器(Decorator)和代理(Proxy),关注于如何组合和构建对象。行为型模式如观察者(Observer)、策略(Strategy)和职责链(Chain of Responsibility),关注对象间的交互和行为...
装饰模式(Decorator Pattern)是Java设计模式中的一种结构型模式,它允许在运行时动态地向对象添加新的行为或职责,而不会破坏封装性。这种模式可以用来将多个功能组合在一起,同时保持类的可扩展性和灵活性。在...
这段代码展示了 Java 中常见的 IO 处理方式,同时引出了一个重要的设计模式——装饰者模式(Decorator Pattern)。装饰者模式是一种结构型设计模式,用于在不改变现有对象结构的情况下动态地给该对象添加新的功能。 ...
在Java的IO库中,装饰器模式得到了广泛应用。例如,`BufferedInputStream`就是一种装饰器,它包装了基本的`InputStream`,增加了缓冲功能,使得读取数据更加高效。装饰器模式下,高级流(如`BufferedInputStream`)...
Java的IO流设计非常优雅,采用了装饰者模式(Decorator Pattern),允许用户动态地组合不同的流,以实现所需的功能。例如,结合使用`FileInputStream`和`BufferedInputStream`可以获得一个具有缓冲功能的文件输入流...