中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中動態代理和反射機制的案例分析

發布時間:2020-10-28 11:51:55 來源:億速云 閱讀:157 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關Java中動態代理和反射機制的案例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

反射機制

Java語言提供的一種基礎功能,通過反射,我們可以操作這個類或對象,比如獲取這個類中的方法、屬性和構造方法等。

動態代理:分為JDK動態代理、cglib動態代理(spring中的動態代理)。

靜態代理

預先(編譯期間)確定了代理者與被代理者之間的關系,也就是說,若代理類在程序運行前就已經存在了,這種情況就叫靜態代理

動態代理

代理類在程序運行時創建的代理方式。也就是說,代理類并不是在Java代碼中定義的,而是在運行期間根據我們在Java代碼中的“指示”動態生成的。

動態代理比靜態代理的優勢在于:

動態代理可以很方便的對代理類的函數進行統一的處理(invoke),而不是修改每個代理類的函數,更靈活和擴展。

JDK的動態代理(依賴于接口)

在Java的動態代理機制中,有兩個重要的類或接口,一個是InvocationHandler接口,另一個是Proxy類。

InvocationHandler接口是給動態代理類實現的,負責處理被代理對象的操作

Proxy類是用來創建動態代理類實例對象的,只有得到這個對象,才能調用需要代理的方法。

動態代理的代理類是在靜態代理類上進行修改,將動態代理類實現InvocationHandler接口,重寫Invoke方法,Invoke方法通過傳入的被代理類方法和參數來執行。

如下實例:

public interface AppService {
	void createApp(String name);
	void deleteApp(String name);
}
//代理類(比如微商代理)
public class AppServiceImpl implements AppService{

	@Override
	public void createApp(String name) {
		System.out.print("App["+name+"] has been created.");
	}

	@Override
	public void deleteApp(String name) {
		System.out.print("App["+name+"] has been delete.");
	}
}

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

public class LoggerInterceptor implements InvocationHandler {
    private Object target; //委托類(被代理類)的實例,比如廠家
    public LoggerInterceptor(Object target){  
        this.target = target;  
    }  
	@Override
	public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
		System.out.println("Entered "+target.getClass().getName()+"-"+method.getName()+",with arguments{"+args[0]+"}");  
        Object result = method.invoke(target, args);
       //調用目標對象的方法  (調用廠家的方法(createApp)及參數(Kevin Test))
        System.out.println("Before return:"+result);  
        return result;  
	}

}
import java.lang.reflect.Proxy;

public class test {

public static void main(String[] args) {
    AppService target = new AppServiceImpl();//生成目標對象 (代理類的對象)
    //接下來創建代理對象 
    AppService proxy = (AppService) Proxy.newProxyInstance( 
    target.getClass().getClassLoader(), 
    target.getClass().getInterfaces(), new LoggerInterceptor(target)); 
    proxy.createApp("Kevin Test1"); 
    proxy.deleteApp("Kevin Test2"); 
  }

}/**
* 1、jdk的動態代理實現方式是依賴于接口的,首先使用接口來定義好操作規范。
* 2、通過proxy類產生的代理對象調用被代理對象的操作。
* 3、而這個操作又被分發給InvocationHandler接口的invoke方法具體執行
* 
* 在java的動態代理機制中,有兩個重要的類或接口,一個是InvocationHandler接口、另一個則是 Proxy類,這個類和接口是實現我們動態代理所必須用到的。
InvocationHandler接口是給動態代理類實現的,負責處理被代理對象的操作的,而Proxy是用來創建動態代理類實例對象的,因為只有得到了這個對象我們才能調用那些需要代理的方法。
* 
* 此方法的參數含義如下 
proxy:代表動態代理對象 
method:代表正在執行的方法 
args:代表當前執行方法傳入的實參 
返回值:表示當前執行方法的返回值
* 
* 如上:
* 使用了Proxy類的newProxyInstance方法生成代理對象,然后用這個對象去調用createApp()和deleteApp()方法,
* 其實系統會將這2個方法分發給invoke()方法區執行。其中proxy對象的類是系統幫我們動態創建了,其實實現了我們的業務接口AppService
* 
*/

cglib動態代理(繼承方式)

cglib動態代理中使用MethodInterceptor來實現動態代理類。

攔截器MethodInterceptor中就是由MethodProxy的InvokSuper方法調用代理方法的。

MethodProxy類生成代理方法和代理方法的簽名。

JDK動態代理和Cglib動態代理的區別:

1、JDK動態代理是實現了被代理對象的接口,Cglib是繼承了被代理對象。

2、Cglib因為是繼承機制,所以無法代理被final修飾的方法。

3、JDK和Cglib都是在運行期間生產字節碼,JDK是直接寫class字節碼,Cglib使用ASM框架寫class字節碼;cglib代理實現更復雜,生成代理類比JDK效率低。

4、JDK調用代理方法,是通過反射實現機制調用,cglib是通過Fashclass機制直接調用方法,效率更高。

Fastcalss機制:

為代理類和被代理類個生成一個class,這個class會為代理類或被代理類的方法分配一個index。

這個index當做一個入參,Fashclass就可以直接定位要調用的方法,并直接進行調用。這樣省去了反射調用,所以效率高。

關于Java中動態代理和反射機制的案例分析就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

曲麻莱县| 霍州市| 金昌市| 壶关县| 凌云县| 云浮市| 武隆县| 宁阳县| 南澳县| 磐石市| 虹口区| 涞水县| 临邑县| 康平县| 宁陵县| 比如县| 开化县| 怀化市| 丰原市| 呼伦贝尔市| 中卫市| 高雄县| 临城县| 柏乡县| 台湾省| 绥德县| 环江| 隆林| 许昌县| 东乌珠穆沁旗| 永定县| 海伦市| 吐鲁番市| 岐山县| 鸡东县| 望谟县| 宁都县| 洛浦县| 育儿| 凤凰县| 瓮安县|