装饰模式
一、概念
装饰模式:动态地给一个类添加一个额外的职责,就增加功能来说,装饰模式比生成子类更加灵活。
二、UML类图
三、基本代码实现
1、 Component接口
public abstract class Component {
public abstract void operation();
}
2、 ConreteComponent
public class ConreteComponent extends Component{
public void operation() {
System.out.println("执行核心操作!");
}
}
3、 Decorator
public class Decorator extends Component{
protected Component component;
public Decorator(Component component){
this.component = component;
}
@Override
public void operation() {
if(component!=null){
component.operation();
}
}
}
4、 ConcreteDecoratorA、ConcreteDecoratorB,其添加了额外的功能decorateOperation
public class ConcreteDecoratorA extends Decorator{
public ConcreteDecoratorA(Component component) {
super(component);
}
public void operation(){
super.operation();
decorateOperation();
}
public void decorateOperation(){
System.out.println("新加的修饰功能A");
}
}
public class ConcreteDecoratorB extends Decorator{
public ConcreteDecoratorB(Component component) {
super(component);
}
public void operation(){
super.operation();
decorateOperation();
}
public void decorateOperation(){
System.out.println("新加的修饰功能B");
}
}
5、测试代码
public class MainTest {
public static void main(String[] args) {
ConreteComponent conreteComponent = new ConreteComponent();
ConcreteDecoratorA concreteDecoratorA = new ConcreteDecoratorA(conreteComponent);
ConcreteDecoratorB concreteDecoratorB = new ConcreteDecoratorB(concreteDecoratorA);
concreteDecoratorB.operation();
}
}
四、总结
装饰模式是为已有的功能动态添加更多功能的一种模式。当系统需要新功能的时候,一般是向旧的类中添加新的代码。这些新加的代码通常是装饰了原有类的核心职责或主要行为。它们在主类中加入了新的字段、新的方法和新的逻辑,从而增加了主类的复杂度,而这些新加入的东西仅仅是为了满足一些只在某种特定情况下才会执行特殊行为的需要。这样,装饰模式提供了一个很好的解决方案,它把每个需要装饰的功能放在单独的类中,并让这个类包装它所要装饰的对象,因此,当需要执行特殊行为时,客户代码就可以在运行时根据需要有选择地、按顺序地使用装饰功能包装对象了。
有效地把类的核心职责和类的装饰功能区分开来。可以去除相关类中重复的装饰逻辑。