装饰模式详解

这篇博客介绍了装饰模式的应用,通过创建ConcreteComponent类实现原始接口operation,并使用ConcreteDecorator和ConcreteDecorator1作为装饰类,扩展了ConcreteComponent的功能。ConcreteDecorator在调用原始方法的基础上增加了额外的操作,实现了对原有功能的增强,而无需修改原始代码。
摘要由CSDN通过智能技术生成

对于装饰模式而言,核心就是装饰类Decorator,假设接口为impl,提供一个原始抽象方法operation,其实现类为Con,提供operation的原始实现,最初的调用应该是创建一个Con的对象直接调用Con的方法。现在想在原始实现方法基础上新增功能,那么就可以借助Decorator实现。

public class Decorator implements Component {
//	关联原抽象业务
	private Component component;
	
	
	public Decorator(Component component) {
		super();
		this.component = component;
	}


	@Override
	public void operation() {
		// TODO 自动生成的方法存根
		if(component != null)
				component.operation();
	}

}
package mode.Decorator;

public class ConcreteComponent implements Component {

	@Override
	public void operation() {
		// TODO 自动生成的方法存根
			System.out.println("这是ConcreteComponent中的原始的接口实现方法!\n");
	}

}

package mode.Decorator;

public interface Component {
	
		public void operation();
}

package mode.Decorator;

public class ConcreteDecorator extends Decorator {

	public ConcreteDecorator(Component component) {
		super(component);
		// TODO 自动生成的构造函数存根
	}

	@Override
	public void operation() {
		// TODO 自动生成的方法存根
//		super.operation();
		System.out.println("这是ConcreteDecorator类中实现Decorator的operation方法后扩展的功能!\n");
	}
	
	

}

package mode.Decorator;

public class ConcreteDecorator1 extends Decorator {

	public ConcreteDecorator1(Component component) {
		super(component);
		// TODO 自动生成的构造函数存根
	}

	@Override
	public void operation() {
		// TODO 自动生成的方法存根
//		super.operation();
		System.out.println("#########################################");
		System.out.println("这是ConcreteDecorator1类中实现Decorator的operation方法后扩展的功能!\n");

	}
	
	
}

PS:
可以根据super自选是否继承原有的方法体。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值