美文网首页
装饰者模式

装饰者模式

作者: 云芈山人 | 来源:发表于2021-07-24 23:32 被阅读0次

    概述

    装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。
    这个模式创建了一个装饰类,用来包装原来的类,并在保持类方法签名完整性的前提下,提供了额外的功能。

    • 意图
      动态的给一个对象添加额外的职责。装饰器模式相比生成子类更为灵活。

    • 主要解决
      一般而言,扩展一个类的经常使用继承方式实现。继承为类引入静态特征,并随扩展功能的增多,子类会膨胀。

    • 何时使用
      扩展类的功能,但不想增加子类数量。

    • 如何解决
      将具体功能职责划分,同时继承装饰者模式。

    • 关键代码

      1. Component充当抽象角色,并不具体实现。
      2. 修饰类引用和继承Component类,具体扩展类重写父类方法。
    • 应用实例
      一个形状可以有不同的颜色。
      孙悟空,作为猴子,拥有72种变化。
      等等

    • 优点
      装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的替代模式,装饰模式可以动态扩展一个类的功能。

    • 缺点
      多层装饰比较复杂。

    • 使用场景

      1. 扩展一个类的功能。
      2. 动态增加功能,撤销功能。

    实现

    一个形状装饰上不同的颜色,同时又不改变形状类。我们将这个场景作为实例来演示装饰器模式的用法。

    • 思路
      1. 创建一个 Shape 接口和实现了 Shape 接口的实体类。
      2. 创建一个实现了 Shape 接口的抽象装饰类 ShapeDecorator,并把 Shape 对象作为它的实例变量。
      3. RedShapeDecorator 实现了 ShapeDecorator 的实体类。
      4. DecoratorPatternDemo 使用 RedShapeDecorator 来装饰 Shape 对象。


        Shape装饰器模式.png
    public interface Shape {
       void draw();
    }
    
    public class Rectangle implements Shape {
     
       @Override
       public void draw() {
          System.out.println("Shape: Rectangle");
       }
    }
    
    public class Circle implements Shape {
     
       @Override
       public void draw() {
          System.out.println("Shape: Circle");
       }
    }
    
    public abstract class ShapeDecorator implements Shape {
       protected Shape decoratedShape;
     
       public ShapeDecorator(Shape decoratedShape){
          this.decoratedShape = decoratedShape;
       }
     
       public void draw(){
          decoratedShape.draw();
       }  
    }
    
    public class RedShapeDecorator extends ShapeDecorator {
     
       public RedShapeDecorator(Shape decoratedShape) {
          super(decoratedShape);     
       }
     
       @Override
       public void draw() {
          decoratedShape.draw();         
          setRedBorder(decoratedShape);
       }
     
       private void setRedBorder(Shape decoratedShape){
          System.out.println("Border Color: Red");
       }
    }
    
    public class DecoratorPatternDemo {
       public static void main(String[] args) {
     
          Shape circle = new Circle();
          ShapeDecorator redCircle = new RedShapeDecorator(new Circle());
          ShapeDecorator redRectangle = new RedShapeDecorator(new Rectangle());
          //Shape redCircle = new RedShapeDecorator(new Circle());
          //Shape redRectangle = new RedShapeDecorator(new Rectangle());
          System.out.println("Circle with normal border");
          circle.draw();
     
          System.out.println("\nCircle of red border");
          redCircle.draw();
     
          System.out.println("\nRectangle of red border");
          redRectangle.draw();
       }
    }
    

    输出结果
    Circle with normal border
    Shape: Circle

    Circle of red border
    Shape: Circle
    Border Color: Red

    Rectangle of red border
    Shape: Rectangle
    Border Color: Red

    相关文章

      网友评论

          本文标题:装饰者模式

          本文链接:https://www.haomeiwen.com/subject/bjemyltx.html