日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何深度剖析Java反射機制中的動態(tài)代理原理

本篇文章給大家分享的是有關(guān)如何深度剖析Java反射機制中的動態(tài)代理原理,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)建站服務(wù)項目包括貢井網(wǎng)站建設(shè)、貢井網(wǎng)站制作、貢井網(wǎng)頁制作以及貢井網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,貢井網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到貢井省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

動態(tài)代理類原理 示例代碼參見《Java反射機制剖析:簡單談?wù)剟討B(tài)代理》)

a) 理解上面的動態(tài)代理示例流程

如何深度剖析Java反射機制中的動態(tài)代理原理

b) 代理接口實現(xiàn)類源代碼剖析

咱們一起來剖析一下代理實現(xiàn)類($Proxy0)的源代碼和整個動態(tài)代理的流程。

$Proxy0生成的代碼如下:

import java.lang.reflect.InvocationHandler;  import java.lang.reflect.Method;  import java.lang.reflect.Proxy;  import java.lang.reflect.UndeclaredThrowableException;     public final class $Proxy0 extends Proxy implements Manager {     private static Method m1;  private static Method m0;  private static Method m3;  private static Method m2;     static {     try {      m1 = Class.forName("java.lang.Object").getMethod("equals",        new Class[] { Class.forName("java.lang.Object") });      m0 = Class.forName("java.lang.Object").getMethod("hashCode",        new Class[0]);      m3 = Class.forName("com.ml.test.Manager").getMethod("test",        new Class[0]);      m2 = Class.forName("java.lang.Object").getMethod("toString",        new Class[0]);     } catch (NoSuchMethodException nosuchmethodexception) {      throw new NoSuchMethodError(nosuchmethodexception.getMessage());     } catch (ClassNotFoundException classnotfoundexception) {      throw new NoClassDefFoundError(classnotfoundexception.getMessage());     }  }     public $Proxy0(InvocationHandler invocationhandler) {     super(invocationhandler);  }     @Override public final boolean equals(Object obj) {     try {      return ((Boolean) super.h.invoke(this, m1, new Object[] { obj }))        .booleanValue();     } catch (Throwable throwable) {      throw new UndeclaredThrowableException(throwable);     }  }     @Override public final int hashCode() {     try {      return ((Integer) super.h.invoke(this, m0, null)).intValue();     } catch (Throwable throwable) {      throw new UndeclaredThrowableException(throwable);     }  }     public final void test() {     try {      super.h.invoke(this, m3, null);      return;     } catch (Error e) {     } catch (Throwable throwable) {      throw new UndeclaredThrowableException(throwable);     }  }     @Override public final String toString() {     try {      return (String) super.h.invoke(this, m2, null);     } catch (Throwable throwable) {      throw new UndeclaredThrowableException(throwable);     }  }  }

引入眼簾的是這個代理接口實現(xiàn)類實現(xiàn)了業(yè)務(wù)類的接口(也就是例子中的UserManager接口),又繼承了基類Proxy類;

接著就是構(gòu)造函數(shù),在構(gòu)造方法中把BusinessHandler傳過去,接著$Proxy0調(diào)用父類Proxy的構(gòu)造器,為h賦值(這里要看Proxy的構(gòu)造方法);

隨后看到的就是這個類重寫了Proxy類的Equals、hashCode、toString方法,又實現(xiàn)了業(yè)務(wù)類接口的方法(即UserManager的test方法),具體重寫和實現(xiàn)都是用到的super.h.invoke(即Proxy.h.invoke)這個方法。

簡單分析完這個代理接口實現(xiàn)類,咱們下面來整體看一下這個動態(tài)代理是怎么實現(xiàn)的:

首先客戶端初始化了BusinessHandler類,調(diào)用這個類的newProxyInstance(new UserManagerImpl())方法來初始化了上面的代理接口實現(xiàn)類;

接下來代理接口實現(xiàn)類通過構(gòu)造函數(shù)把BusinessHandler傳過去(也就是代碼中的this),并通過Proxy的構(gòu)造函數(shù)給h賦值;

隨后再客戶端就能實例化出代理接口實現(xiàn)類$Proxy0,我們把它強制轉(zhuǎn)換為業(yè)務(wù)實現(xiàn)接口(UserManager)類型的(為什么要強制轉(zhuǎn)換,這里非常有意思,如果不強制轉(zhuǎn)換就會報錯,這里很好解釋,因為當(dāng)前的環(huán)境根本不會知道這個代理接口實現(xiàn)類$Proxy0既繼承Proxy又實現(xiàn)業(yè)務(wù)實現(xiàn)接口UserManager,但是強制轉(zhuǎn)換成UserManager它是可以做到的,因為當(dāng)前環(huán)境中就有UserManager。這就是反射的厲害之處,可以在運行時動態(tài)調(diào)用任何一個類并可以使用這個類的具體細(xì)節(jié)。);

之后當(dāng)我們調(diào)用test方法的時候其實是調(diào)用了$Proxy0中的test方法,這個方法的實現(xiàn)是通過Proxy.h的invoke方法實現(xiàn)的(即調(diào)用了BusinessHandler.invoke方法);

之后在調(diào)用了Method的invoke方法(這時的參數(shù)是this,和args)。

這樣就調(diào)用了UserManagerImpl的對應(yīng)方法,之后返回給客戶端。

到此就完成了整個的調(diào)用關(guān)系。

反射,反射,程序員的快樂

通過上篇文章對動態(tài)代理進(jìn)行了深度剖析,現(xiàn)在想起來還感覺非常有意思,這里面其實最根本的機制就是反射機制,運行時動態(tài)實例化任何一個類,并且調(diào)用它的具體細(xì)節(jié)?,F(xiàn)在反看動態(tài)代理的示例,其實發(fā)現(xiàn)這里最關(guān)鍵的還是在就在Proxy.newProxyInstance(..)方法執(zhí)行時生成了$Proxy0的內(nèi)存字節(jié)碼這一點上,當(dāng)我們有了內(nèi)存字節(jié)碼,我們的反射就會大顯威力,這樣才有了我們之后的一系列的調(diào)用關(guān)系。

通過反射機制的分析和動態(tài)代理示例的剖析,發(fā)現(xiàn)編程是一件多么有意思的事情,以至于我們沉浸其中不能自拔。

以上就是如何深度剖析Java反射機制中的動態(tài)代理原理,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


分享名稱:如何深度剖析Java反射機制中的動態(tài)代理原理
URL地址:http://www.dlmjj.cn/article/pggeoj.html