文章23 | 阅读 8308 | 点赞0
装饰者(Decorator)模式:动态地将责任附加到对象上,若要扩展功能,装饰者提供了比继承更具有弹性的替代方案。对于装饰者模式,它其实是一种包装,所以我更愿意称它为一种包装。像咱们以前经常使用的Java里面的IO流就用到了装饰者模式。比如:BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(file1)));这里file1为目标对象,而像BufferedReader、InputStreamReader就可以称之为包装类。下面举例说明:
/**
* 对修改关闭,对扩展开放。
*
* 统一接口
*/
interface Filterable {
public void filter();
}
/**
* 目标类
*/
class Filter implements Filterable {
@Override
public void filter() {
System.out.println("目标类的核心过滤方法...");
}
}
/**
* DecoratorForFilter1包装类与目标类实现相同的接口 --> 织入Log
*/
class DecoratorForFilter1 implements Filterable {
private Filterable filterable;
public DecoratorForFilter1(Filterable filterable) {
this.filterable = filterable;
}
private void beforeMethod() {
System.out.println("DecoratorForFilter1 --> 核心过滤方法执行前执行");
}
private void afterMethod() {
System.out.println("DecoratorForFilter1 --> 核心过滤方法执行后执行");
}
@Override
public void filter() {
beforeMethod();
filterable.filter();
afterMethod();
}
}
/**
* DecoratorForFilter2包装类与目标类实现相同的接口 --> 织入Log
*/
class DecoratorForFilter2 implements Filterable {
private Filterable filterable;
public DecoratorForFilter2(Filterable filterable) {
this.filterable = filterable;
}
private void beforeMethod() {
System.out.println("DecoratorForFilter2 --> 核心过滤方法执行前执行");
}
private void afterMethod() {
System.out.println("DecoratorForFilter2 --> 核心过滤方法执行后执行");
}
@Override
public void filter() {
beforeMethod();
filterable.filter();
afterMethod();
}
}
/**
* 客户端测试类
*
* @author Leo
*/
public class Test {
public static void main(String[] args) {
/**
* 目标对象
*/
Filterable targetObj = new Filter();
/**
* 包装对象(对目标对象进行包装)
*/
Filterable decorObj = new DecoratorForFilter1(new DecoratorForFilter2(
targetObj));
/**
* 执行包装后的业务方法
*/
decorObj.filter();
}
}
输出:
DecoratorForFilter1 --> 核心过滤方法执行前执行
DecoratorForFilter2 --> 核心过滤方法执行前执行
目标类的核心过滤方法...
DecoratorForFilter2 --> 核心过滤方法执行后执行
DecoratorForFilter1 --> 核心过滤方法执行后执行
I/O、过滤器
通过输入的Log我们可以看到:输出的过程其实是将包装类“拆包”的过程,就像包装袋一样一层一层的拆开。
设计原则:1)多用组合,少用继承。2)对扩展开放,对修改关闭。
内容来源于网络,如有侵权,请联系作者删除!