成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

設計模式之裝飾器模式

開發
裝飾器模式可以將不同功能的單個模塊規劃至不同的裝飾器類中,各裝飾器類獨立自主,各司其職。

裝飾器模式(Decorator Pattern)是一種結構型設計模式,它可以在不改變現有對象的結構的情況下,動態地給對象增加一些額外的功能。裝飾器模式通過創建一個包裝對象(即裝飾器)來包裹真實對象,并在保持真實對象的接口不變的前提下,為其提供額外的功能。裝飾器模式可以在運行時根據需要選擇不同的裝飾器來組合和修改對象的行為。

  • Component(組件接口):所有被裝飾組件及裝飾器對應的接口標準,指定進行裝飾的行為方法。對應下文的的組件接口 Shape 。
  • ConcreteComponent(組件實現):需要被裝飾的組件,實現組件接口標準,只具備自身未被裝飾的原始特性。對應下文的的具體組件 Circle 、Rectangle 。
  • Decorator(裝飾器):裝飾器的高層抽象類,同樣實現組件接口標準,且包含一個被裝飾的組件。對應下文的抽象裝飾器 ShapeDecorator 。
  • ConcreteDecorator(裝飾器實現):繼承自裝飾器抽象類的具體子類裝飾器,可以有多種實現,在被裝飾組件對象的基礎上為其添加新的特性。對應下文的具體裝飾器類 RedShapeDecorator 、GreenShapeDecorator 。

優缺點

裝飾器模式的優點有:

  • 裝飾器模式是繼承的有力補充,比繼承靈活,在不改變原有對象的情況下,動態地給一個對象擴展功能,即插即用。
  • 通過使用不同的裝飾器及這些裝飾器的排列組合,可以實現不同效果。
  • 裝飾器模式完全遵守開閉原則,可以在不修改原有代碼的基礎上增加新的功能。

裝飾器模式的缺點有:

  • 裝飾器模式會增加許多子類,過度使用會增加程序的復雜性。
  • 裝飾器模式會增加對象之間的聯系,可能會引入循環引用的問題。
  • 裝飾器模式會影響對象的標識,當使用裝飾器對對象進行包裝時,對象的類型和行為可能會發生變化。

應用場景

裝飾器模式適用于以下場景:

  • 當需要給一個現有的類添加附加職責,而又不能采用繼承的方式時,可以使用裝飾器模式。例如,在不修改原有代碼的情況下給一個窗口添加滾動條或者邊框等功能。
  • 當需要動態地給一個對象增加功能,而又需要撤銷該功能時,可以使用裝飾器模式。例如,在電子商務系統中根據用戶選擇的不同優惠券來計算商品價格時,可以使用裝飾器模式來實現。
  • 當需要為一批兄弟類進行改裝或加裝功能時,可以使用裝飾器模式。例如,在一個圖形界面工具箱中為多個不同的組件提供一些公共的功能時,可以使用裝飾器模式來實現。

java 代碼示例

以下是一個實現裝飾器模式的 java 示例代碼

1.定義了一個抽象組件接口 Shape 和兩個具體組件類 Circle 和 Rectangle,

//抽象組件接口
public interface Shape {
    void draw();
}

//具體組件類:圓形
public class Circle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a circle");
    }
}

//具體組件類:矩形
public class Rectangle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a rectangle");
    }
}

2.定義一個抽象裝飾器類 ShapeDecorator 和兩個具體裝飾器類 RedShapeDecorator 和 GreenShapeDecorator,

//抽象裝飾器類
public abstract class ShapeDecorator implements Shape {
    //持有一個抽象組件對象
    protected Shape shape;

    //構造方法
    public ShapeDecorator(Shape shape) {
        this.shape = shape;
    }

    //調用被包裝對象的方法
    @Override
    public void draw() {
        shape.draw();
    }
}

//具體裝飾器類:紅色裝飾器
public class RedShapeDecorator extends ShapeDecorator {
    //構造方法
    public RedShapeDecorator(Shape shape) {
        super(shape);
    }

    //重寫draw方法,在調用被包裝對象的方法之前或之后添加新的功能
    @Override
    public void draw() {
        //調用被包裝對象的方法
        super.draw();
        //添加新的功能
        setRedBorder();
    }

    //定義新的功能方法
    private void setRedBorder() {
        System.out.println("Setting red border");
    }
}

//具體裝飾器類:綠色裝飾器
public class GreenShapeDecorator extends ShapeDecorator {
    //構造方法
    public GreenShapeDecorator(Shape shape) {
        super(shape);
    }

    //重寫draw方法,在調用被包裝對象的方法之前或之后添加新的功能
    @Override
    public void draw() {
        //調用被包裝對象的方法
        super.draw();
        //添加新的功能
        setGreenBorder();
    }

    //定義新的功能方法
    private void setGreenBorder() {
        System.out.println("Setting green border");
    }
}

3.編寫裝飾器模式測試代碼,main 函數中創建了不同的組件和裝飾器對象,并調用了它們的方法,

//測試類
public class DecoratorPatternDemo {
    public static void main(String[] args) {
        //創建一個圓形對象
        Shape circle = new Circle();
        //創建一個矩形對象
        Shape rectangle = new Rectangle();
        //創建一個紅色裝飾器對象,包裝圓形對象
        Shape redCircle = new RedShapeDecorator(circle);
        //創建一個綠色裝飾器對象,包裝矩形對象
        Shape greenRectangle = new GreenShapeDecorator(rectangle);

        //調用各個對象的方法,展示不同的效果
        System.out.println("Normal circle:");
        circle.draw();
        System.out.println("Normal rectangle:");
        rectangle.draw();
        System.out.println("Red circle:");
        redCircle.draw();
        System.out.println("Green rectangle:");
        greenRectangle.draw();
    }
}

輸出結果如下:

Normal circle:
Drawing a circle
Normal rectangle:
Drawing a rectangle
Red circle:
Drawing a circle
Setting red border
Green rectangle:
Drawing a rectangle
Setting green border

Spring 代碼示例

要想再 Spring 項目中應用裝飾器模式,只需對以上代碼進行簡單改造即可,

1.給具體組件類 Circle、Rectangle 添加 @Component 注解,

@Component
public class Rectangle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a rectangle");
    }
}

@Component
public class Rectangle implements Shape {
    @Override
    public void draw() {
        System.out.println("Drawing a rectangle");
    }
}

2.給具體裝飾器類 RedShapeDecorator 和 GreenShapeDecorator 類添加 @Component 注解,

@Component
public class GreenShapeDecorator extends ShapeDecorator {
    // 構造方法
    public GreenShapeDecorator(@Qualifier("rectangle") Shape shape) {
        super(shape);
    }

    // 重寫draw方法,在調用被包裝對象的方法之前或之后添加新的功能
    @Override
    public void draw() {
        // 調用被包裝對象的方法
        super.draw();
        // 添加新的功能
        setGreenBorder();
    }

    // 定義新的功能方法
    private void setGreenBorder() {
        System.out.println("Setting green border");
    }
}

@Component
public class RedShapeDecorator extends ShapeDecorator {
    // 構造方法
    public RedShapeDecorator(@Qualifier("circle") Shape shape) {
        super(shape);
    }

    // 重寫draw方法,在調用被包裝對象的方法之前或之后添加新的功能
    @Override
    public void draw() {
        // 調用被包裝對象的方法
        super.draw();
        // 添加新的功能
        setRedBorder();
    }

    // 定義新的功能方法
    private void setRedBorder() {
        System.out.println("Setting red border");
    }
}

3.編寫 Spring 項目測試代碼,

@SpringBootTest
@RunWith(SpringRunner.class)
public class DecoratorTest {

    // 從Spring容器中獲取Context對象
    @Autowired
    private RedShapeDecorator redCircle;
    @Autowired
    private GreenShapeDecorator greenRectangle;

    @Test
    public void test() {
        System.out.println("Red circle:");
        redCircle.draw();
        System.out.println("Green rectangle:");
        greenRectangle.draw();
    }
}

輸出結果如下:

Red circle:
Drawing a circle
Setting red border
Green rectangle:
Drawing a rectangle
Setting green border

總結

裝飾器模式可以將不同功能的單個模塊規劃至不同的裝飾器類中,各裝飾器類獨立自主,各司其職。客戶端可以根據自己的需求自由搭配各種裝飾器,每加一層裝飾就會有新的特性體現出來,巧妙的設計讓功能模塊層層疊加,裝飾之上套裝飾,最終使原始對象的特性動態地得到增強。

責任編輯:趙寧寧 來源: waynblog
相關推薦

2023-12-13 13:28:16

裝飾器模式Python設計模式

2020-12-01 07:16:05

重學設計模式

2022-03-25 11:01:28

Golang裝飾模式Go 語言

2022-01-19 08:21:12

設計裝飾器模式

2024-02-23 12:11:53

裝飾器模式對象

2021-06-22 15:27:13

設計模式迭代器模式Java

2010-04-29 08:53:11

PHP迭代器模式

2021-07-12 10:24:36

Go裝飾器代碼

2010-04-21 08:38:18

解釋器模式PHP設計模式

2020-08-21 07:23:50

工廠模式設計

2024-04-10 12:27:43

Python設計模式開發

2015-09-08 13:39:10

JavaScript設計模式

2021-06-16 08:56:06

模版方法模式設計模式行為型設計模式

2012-01-13 15:59:07

2021-12-24 07:50:45

責任鏈模式設計

2021-06-29 08:54:23

設計模式代理模式遠程代理

2021-06-09 08:53:34

設計模式策略模式工廠模式

2012-02-29 09:41:14

JavaScript

2020-11-09 08:20:33

解釋器模式

2023-05-15 08:51:46

解釋器模式定義
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美伊人久久久久久久久影院 | av中文字幕网 | 欧美成人a∨高清免费观看 欧美日韩中 | 毛片免费视频 | 国产精品视频一二三区 | 国产高清一区二区三区 | 国产一区二区在线免费观看 | 中文字幕亚洲视频 | 中文字幕在线观看一区 | 天天干夜夜操 | 午夜影院免费体验区 | 日韩精品999 | 欧美一级黄色片免费观看 | 日韩视频在线免费观看 | 极品电影院 | 精精国产xxxx视频在线野外 | 亚洲精品一区二区三区四区高清 | 欧美激情综合色综合啪啪五月 | 99福利视频| 久久久久久国产精品免费 | 欧美91| 999久久精品| 国产xxxx岁13xxxxhd | 黄网免费看 | 麻豆视频国产在线观看 | 国产真实精品久久二三区 | 欧美另类视频 | 亚洲精品一二区 | 色精品视频 | 日韩伦理电影免费在线观看 | 久久激情av | 精品久久久久久久久久久久 | 午夜视频免费在线 | av手机在线看 | 国产精品国产a级 | av在线三级 | 欧美日韩在线观看一区 | 国产精品178页 | 久久高清免费视频 | 国产aⅴ爽av久久久久久久 | 午夜精品久久久久99蜜 |