二话不说,看代码先 package com.zq.designpattern;import java.util.Random;/** * Created by zhengshouzi on 2015/10/28. */interface OutputStream{ void write(String string);}class StringOutputStream implements OutputStream{ @Override public void write(String string) { System.out.println('写 '+ string + ' 到文件'); }}abstract class FilterOutputStream implements OutputStream{}class EncryptString_1_OutputStream extends FilterOutputStream{ OutputStream outputStream; public EncryptString_1_OutputStream(OutputStream outputStream){ this.outputStream = outputStream; } @Override public void write(String string) { char[] chars = string.toCharArray(); StringBuilder sb = new StringBuilder(); System.out.println('源字符串: '+string+' 开始简单加密(装饰):每一字符自身加上1'); for (int i=0;i 一共有三个用来加密的装饰者类,他们都能装饰原来的StringOutputStream 类,使原来的StringOutputStream具有各种想要的的功能,分别创建被装饰者,然后将被装饰者作为装饰者类的构造参数,这样完成了装饰功能。 概述: 动态地给一个对象添加一些额外的职责。就增加功能来说,Decorator模式相比生成子类更为灵活。 类型:结构型模式。 适用性: 1、在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。 2、处理那些可以撤消的职责。 3、当不能采用生成子类的方法进行扩充时。 参与者: 1、Component(OutputStream接口) 定义一个对象接口,可以给这些对象动态地添加职责。 2、ConcreteComponent(StringOutputStream类) 定义一个对象,可以给这个对象添加一些职责。 3、Decorator() 维持一个指向Component对象的指针,并定义一个与Component接口一致的接口。 4、ConcreteDecorator(各个具体的加密类) 向组件添加职责。 装饰模式的优缺点l 比继承更灵活 l 更容易复用功能 l 简化高层定义 l 会产生很多细粒度对象 思考装饰模式1:装饰模式的本质 装饰模式的本质:动态组合。 动态是手段,组合才是目的。这里的组合有两个意思,一个是动态功能的组合,也就是动态进行装饰器的组合;另外一个是指对象组合,通过对象组合来实现为被装饰对象透明的增加功能。 但是要注意,装饰模式不仅仅可以增加功能,也可以控制功能的访问,可以完全实现新的功能,还可以控制装饰的功能是在被装饰功能之前还是之后来运行等。 总之,装饰模式是通过把复杂功能简单化,分散化,然后在运行期间,根据需要来动态组合的这么一个模式。 2:何时选用装饰模式 建议在如下情况中,选用装饰模式:
|
|