Java设计模式(二) Decorator(装饰)模式及Java I/O引申
2016-04-13 19:37
666 查看
基本概念
Decorator
职能上:动态地给一个对象添加一些额外的职责,就增加功能来说
Decorator比从基类生成子类更灵活,而且能有效地控制子类的数量,防止子类爆炸(后面的特性会印证这个优势)。
结构(工作原理)上:
可以创建始于Decorator对象(负责新功能的对象)终于原对象的一个对象链
实现上:
Decorator模式将Decrator对象(能够提供额外的功能)与这些对象的使用规则分离开来,因为每个对象只关注自己的功能,而不关注自己按照如何添加到对象链中
这使我们有机会任意重排Decorator对象并串联,而无须改变其的任何代码。
因为功能的分离,Decorator对象有更好的内聚性
通过继承基类实现子类的方式因为对于每个排列都要重新实现,所以难以避免子类爆炸的问题。
Decorator模式能够将子类数量控制在Decorator级别,理论上与继承方法相比是N!的差别。
因为避免了继承,所以自然而然获得了更好的封装性
组成上:
Component(组件):组件的抽象,包括装饰者和被装饰者
Concrete Component(原始组件):被装饰的对象,也就是被装饰者
Decorator(装饰者):具体的装饰组件的抽象,包含一个抽象component的构件(具体可能是原始组件,也可能是装饰者),继承自Component
Concrete Decorator:具体的装饰组件,用于实现具体的附加功能。
例讲Decorator(装饰者)模式
现在还处于实习生招生季,简历是一切的基石,毕竟简历不过,哪怕你是大牛,连面试的机会都没有,岂不是开心的不行,往往我们的简历是有针对性的,对于不同的公司和不同的岗位,应聘腾讯后台,鼓吹阿里和Java就是你的不对了……可是给每个公司都写一份简历,那就不开心了,所以我们可以采用装饰者模式基本角色的实现
Component:
abstract class Component { public abstract void print(); }
Decorator:
abstract class Decorator extends Component{ private Component component; Decorator( Component component ){ this.component = component; } @Override public void print(){ component.print(); } }
Concrete Component:
class Resume extends Component{ @Override public void print() { System.out.println("My Name: llin\n" +"My Major: Software Engineering" +"My University: Tianjin University" ); } }
Concrete Decorator:
class AliDecrator extends Decorator{ AliDecrator(Component component) { super(component); } @Override public void print() { super.print(); System.out.println("I want a position at Ali major in Java"); } } class TencentDecorator extends Decorator{ TencentDecorator(Component component) { super(component); } @Override public void print(){ super.print(); System.out.println("I want a position at QQ major in C++"); } }
测试用类:
public class decoratorEg { public static void main ( String [] args ){ Component resume = new Resume(); Component aliResume = new AliDecrator( resume ); Component QQResume = new TencentDecorator( resume ); aliResume.print(); System.out.println(""); QQResume.print(); } }
测试结果如下:(其实在大量拓展,大量排列组合时才能更好地凸显出Decorator模式的优势)
Decorator的应用场景
装饰类和被装饰类可以独立发展,而不会互相耦合,所以具有易维护的特性相对于继承,能够有效地防止子类爆炸,具有易拓展性和易复用性
装饰者模式是继承关系的一种替代方案,我们通过例子可以看出,装饰之后返回的依然是Component的接口,实现的是一个is-a的关系。
Java I/O中的Decorator模式
在InputStream和OutputStream上添加各种功能,类似缓存、文件读入等等一系列功能拓充都是Decorator模式下的产物Decorator和Adapter两种模式的比较
两种模式都是包装模式,都是起到包装一个对象或类的作用适配器的意义在于将一个接口包装成另一个接口,它的目的是通过改变接口达到重复使用的作用
装饰器不改变对象的接口,而是恰恰要保持原来的接口,但是增强原有对象的功能,或改变原有对象的处理方法而提升性能。
这次没有鸡汤…………
相关文章推荐
- Myeclipse2014 安装反编译插件
- Java Web项目中Maven管理jar包,如何用命令添加ja包!
- Spring事务之事务控制方式
- Java中的排序方法(冒泡排序 和 选择排序)
- Intellij idea 和myeclipse的最常用快捷键
- Java中的数组
- SpringMvc 上传excel(注解和非注解两种方式)
- Java 基本语法
- Spring事务之如何保证同一个Connection对象
- MyBatis-Spring-TransactionManager
- 开博第一天,想写点有意义的东西!
- java jdbc工具类
- storm 报错:java.nio.channels.ClosedChannelException: null
- JAVA环境变量JAVA_HOME、CLASSPATH、PATH设置详解
- Java学习-7天
- Java学习-6天
- Java垃圾回收机制
- 用STS和Maven的方式创建一个JavaWeb项目
- Spring 加载数据配置文件
- Struts.xml 出现文档无效,语法错误