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

如何用裝飾者模式代理final方法

開發 前端
創建一個和目標類相同的接口,或者如果目標類已經實現了一個接口,你可以直接使用它。這個接口定義了目標類的所有公共方法,包括final方法。

裝飾者模式

裝飾者模式是一種結構型設計模式,它可以在不改變對象的原有結構的情況下,動態地給對象添加新的功能和職責。裝飾者模式的核心思想是使用組合和委托的方式,讓裝飾者類持有一個被裝飾對象的引用,并在調用被裝飾對象的方法之前或之后添加新的行為。這樣,裝飾者類可以在運行時動態地修改被裝飾對象的行為,而不需要創建大量的子類。

代碼示例:

// 定義抽象組件類,它是一個接口,定義了被裝飾對象和裝飾對象共同實現的方法
interface Component {
    void operation();
}

// 定義具體組件類,它是一個實現了抽象組件接口的具體對象
class ConcreteComponent implements Component {
    public void operation() {
        System.out.println("具體組件的操作");
    }
}

// 定義裝飾者抽象類,它繼承了抽象組件類,并持有一個抽象組件的引用
abstract class Decorator implements Component {
    protected Component component; // 通過構造函數傳入被裝飾對象

    public Decorator(Component component) {
        this.component = component;
    }

    public void operation() {
        component.operation(); // 可以在調用被裝飾對象的方法之前或之后添加新的行為
    }
}

// 定義具體裝飾者類,它繼承了裝飾者抽象類,并在其中添加新的行為或功能
class ConcreteDecoratorA extends Decorator {
    public ConcreteDecoratorA(Component component) {
        super(component);
    }

    public void operation() {
        super.operation(); // 調用父類的方法
        addedBehavior(); // 調用自己的方法
    }

    public void addedBehavior() {
        System.out.println("具體裝飾者A的操作");
    }
}

// 定義具體裝飾者類,它繼承了裝飾者抽象類,并在其中添加新的行為或功能
class ConcreteDecoratorB extends Decorator {
    public ConcreteDecoratorB(Component component) {
        super(component);
    }

    public void operation() {
        super.operation(); // 調用父類的方法
        addedBehavior(); // 調用自己的方法
    }

    public void addedBehavior() {
        System.out.println("具體裝飾者B的操作");
    }
}

// 測試代碼
public class DecoratorPatternDemo {
    public static void main(String[] args) {
        Component component = new ConcreteComponent(); // 創建被裝飾對象
        Component decoratorA = new ConcreteDecoratorA(component); // 創建具體裝飾者A,并傳入被裝飾對象
        Component decoratorB = new ConcreteDecoratorB(decoratorA); // 創建具體裝飾者B,并傳入具體裝飾者A
        decoratorB.operation(); // 調用具體裝飾者B的方法,輸出如下:
        // 具體組件的操作
        // 具體裝飾者A的操作
        // 具體裝飾者B的操作
    }
}

步驟:

  • 首先,創建一個和目標類相同的接口,或者如果目標類已經實現了一個接口,你可以直接使用它。這個接口定義了目標類的所有公共方法,包括final方法。
  • 然后創建一個裝飾者類,實現這個接口,并在構造函數中傳入一個目標類的實例。在裝飾者類中,可以為每個方法添加代理邏輯,比如打印日志、檢查權限等。然后,可以調用目標類的對應方法,或者直接返回結果。
  • 最后,創建一個裝飾者類的實例,并傳入一個目標類的實例。這樣,就可以通過裝飾者類來代理目標類的所有方法,包括final方法。

代碼示例:

假設有一個目標類叫做HelloService,它有一個final方法叫做sayHello:

// 定義一個目標類,其中有一個final方法
class Target {
    public final void finalMethod() {
        System.out.println("目標類的final方法");
    }
}

// 定義一個裝飾者抽象類,它持有一個目標對象的引用
abstract class Decorator {
    protected Target target; // 通過構造函數傳入目標對象

    public Decorator(Target target) {
        this.target = target;
    }

    public abstract void operation(); // 定義一個抽象方法,用于增強目標對象
}

// 定義一個具體裝飾者類,它繼承了裝飾者抽象類,并在其中添加新的行為或功能
class ConcreteDecorator extends Decorator {
    public ConcreteDecorator(Target target) {
        super(target);
    }

    public void operation() {
        before(); // 調用自己的方法
        target.finalMethod(); // 調用目標對象的final方法
        after(); // 調用自己的方法
    }

    public void before() {
        System.out.println("調用final方法之前");
    }

    public void after() {
        System.out.println("調用final方法之后");
    }
}

// 測試代碼
public class DecoratorPatternDemo {
    public static void main(String[] args) {
        Target target = new Target(); // 創建目標對象
        Decorator decorator = new ConcreteDecorator(target); // 創建具體裝飾者,并傳入目標對象
        decorator.operation(); // 調用具體裝飾者的方法,輸出如下:
        // 調用final方法之前
        // 目標類的final方法
        // 調用final方法之后
    }
}

這樣做并不是真正意義上的動態代理,因為您需要顯式地創建裝飾者對象,并傳入目標對象。而且,如果目標類有多個final方法,您可能需要為每個方法都創建一個裝飾者類,這會增加代碼的復雜度和冗余。

裝飾者模式和JDK代理的區別:

  • 裝飾者模式和JDK代理都是使用組合而不是繼承來擴展對象的功能,但是它們的目的和實現方式不同。
  • 裝飾者模式是為了增強對象本身的功能,而JDK代理是為了控制對對象的訪問,比如添加權限檢查、日志記錄等。
  • 裝飾者模式是客戶端透明的,也就是說客戶端不需要知道被裝飾的對象是怎么被裝飾的,只需要使用它的增強功能即可。而JDK代理是客戶端不透明的,也就是說客戶端只能看到代理對象,而不能直接訪問被代理的對象。
  • 裝飾者模式是動態的,也就是說可以在運行時根據需要給對象添加不同的裝飾者。而JDK代理是靜態的,也就是說在編譯時就確定了代理對象和被代理對象的關系,不能在運行時改變。
  • 裝飾者模式和JDK代理都需要實現一個共同的接口,以保證類型的一致性。但是裝飾者模式需要在構造函數中傳入被裝飾的對象,而JDK代理則需要通過反射機制來創建被代理的對象。

實際上可以使用Spring AOP實現final方法的代理

// 定義一個目標類,包含一個final方法
public class Target {
    public final void sayHello() {
        System.out.println("你好,我是目標");
    }
}

// 定義一個切面類,用來編寫增強邏輯
@Aspect
public class AspectDemo {
    // 定義一個前置通知,用@Before注解指定切入點表達式,匹配目標類的final方法
    @Before("execution(final void com.example.Target.sayHello())")
    public void beforeAdvice() {
        System.out.println("建議之前:這是最后的方法");
    }
}

// 定義一個測試類,用來創建代理對象并調用目標方法
public class TestDemo {
    public static void main(String[] args) {
        // 創建目標對象
        Target target = new Target();
        // 創建代理工廠
        AspectJProxyFactory factory = new AspectJProxyFactory(target);
        // 添加切面類
        factory.addAspect(AspectDemo.class);
        // 獲取代理對象
        Target proxy = factory.getProxy();
        // 調用代理對象的final方法
        proxy.sayHello();
    }
}
/**
建議之前:這是最后的方法
你好,我是目標**/


責任編輯:武曉燕 來源: 今日頭條
相關推薦

2020-12-01 07:16:05

重學設計模式

2022-11-26 00:00:06

裝飾者模式Component

2024-04-10 12:27:43

Python設計模式開發

2022-09-14 08:16:48

裝飾器模式對象

2021-07-12 10:24:36

Go裝飾器代碼

2023-09-04 13:14:00

裝飾器設計模式

2022-03-25 11:01:28

Golang裝飾模式Go 語言

2023-12-13 13:28:16

裝飾器模式Python設計模式

2009-03-18 11:36:21

代理服務器下載MyEclipse7.

2021-09-08 07:18:30

代理模式對象

2020-08-11 10:40:31

裝飾者模式Java組件

2022-06-20 08:16:42

享元模式優化系統內存

2011-04-06 11:41:25

Java動態代理

2023-09-24 13:07:53

NginxMySQLIP

2022-01-19 08:21:12

設計裝飾器模式

2012-01-13 15:59:07

2021-06-29 08:54:23

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

2012-02-29 09:41:14

JavaScript

2022-09-04 15:40:39

JavaScrip狀態模式軟件

2024-02-23 12:11:53

裝飾器模式對象
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产农村妇女精品一区 | 五月婷婷中文 | 亚洲成人免费观看 | 日本不卡一区二区三区 | 色av一区二区三区 | 国产精品网址 | 日韩免费一区二区 | 91成人免费| 男女污污动态图 | 日韩av大片免费看 | 国产精品综合视频 | 精品日韩一区二区 | 亚洲欧美国产毛片在线 | 成人在线视频网站 | 91精品综合久久久久久五月天 | 中文亚洲字幕 | 亚洲天堂久久 | 玖玖综合网 | 九九热国产精品视频 | 亚洲精品一级 | 综合久久国产 | 久久综合国产精品 | 在线一区二区三区 | 久久久久久久91 | 黄色毛片在线看 | 久久久久久久久久久久91 | xx性欧美肥妇精品久久久久久 | 精品www| 欧美久久一区二区 | 欧美区在线观看 | 日韩资源 | 亚洲男人的天堂网站 | 欧美在线精品一区 | 成人福利在线观看 | 在线视频三区 | 一区二区在线观看av | 亚洲精品久久久久久久久久久 | 欧美视频成人 | 四虎影院在线观看av | 精品欧美乱码久久久久久 | 日韩中文字幕 |