本篇內(nèi)容介紹了“InvocationHandler的invoke調(diào)用次數(shù)不正常是什么情況”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)建站是一家專注于網(wǎng)站制作、成都網(wǎng)站設(shè)計和樂山服務(wù)器托管的網(wǎng)絡(luò)公司,有著豐富的建站經(jīng)驗和案例。
大概意思就是:同一份動態(tài)代碼實(shí)驗代碼,放在Eclipse中測試一切正常,但放在IDEA 中的springboot項目中測試時就不正常。
動態(tài)代理實(shí)驗,一個接口:
public interface DestInterface {
void fun(String msg);
}
這個接口的實(shí)現(xiàn)類:
public class DestClass implements DestInterface {
public void fun(String msg) {
System.out.println("DestClass.fun "+ msg);
}
}
一個InvocationHandler接口的實(shí)現(xiàn)類:
public class DynamicProxy implements InvocationHandler {
private Object object;//要代理的真正對象
public DynamicProxy(Object obj) //構(gòu)造并傳遞真正的對象
{
object = obj;
}
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("before proxy proxy class is " + proxy.getClass());
System.out.println("method is " + method + ":"+method.getName() + ":"+ method.getDeclaringClass() + ":"+ method.getReturnType());
// Object obj = method.invoke(object,args); //出現(xiàn) IllegalArgumentException: object is not an instance of declaring class
// Object obj = method.invoke(proxy,args); //總是不停地執(zhí)行,不明白為什么會這樣
Object obj = method.invoke(object,args);//出現(xiàn)類不匹配的原因是:主程序中InvocationHandler invocationHandler = new DynamicProxy(someservice);
//其實(shí)在InvocationHandler實(shí)例化對象的時候,傳入的是真正的要在其上執(zhí)行函數(shù)的對象,這個對象所在類應(yīng)該繼承了一個或多個接口,當(dāng)然這些接口在Proxy.newInstance
// 創(chuàng)建代理對象的時候?qū)⑦@些接口的Class傳入。也就是說new InvocationHandler對象的時候參數(shù)應(yīng)該是目標(biāo)類的對象,此例是DestInterface的實(shí)現(xiàn)類的對象
System.out.println("after proxy vaue="+obj);
return null;
}
}
具體要想使用動態(tài)代理對象的代碼如下:
DestInterface destInterface = new DestClass();//真正的目標(biāo)對象 InvocationHandler invocationHandler = new DynamicProxy(destInterface); DestInterface o = (DestInterface)Proxy.newProxyInstance(invocationHandler.getClass().getClassLoader(),destInterface.getClass().getInterfaces(),invocationHandler); o.fun("abc");
在Eclipse中顯示如下:
before proxy proxy class is class com.sun.proxy.$Proxy0
method is public abstract void com.joe.DestInterface.fun(java.lang.String):fun:interface com.joe.DestInterface:void
DestClass.fun abc
after proxy vaue=null
但在IDEA的springboot項目中顯示如下:
before proxy proxy class is class com.sun.proxy.$Proxy41
method is public java.lang.String java.lang.Object.toString():toString:class java.lang.Object:class java.lang.String
after proxy vaue=com.joe.DestClass@1e53135d
before proxy proxy class is class com.sun.proxy.$Proxy41
method is public abstract void com.joe.DestInterface.fun(java.lang.String):fun:interface com.joe.DestInterface:void
DestClass.fun himsg
after proxy vaue=null
before proxy proxy class is class com.sun.proxy.$Proxy41
method is public java.lang.String java.lang.Object.toString():toString:class java.lang.Object:class java.lang.String
after proxy vaue=com.joe.DestClass@1e53135d
在IDEA中調(diào)試時發(fā)現(xiàn)當(dāng)執(zhí)行完P(guān)roxy.newInstance這一句之后居然發(fā)現(xiàn)會進(jìn)入DymicProxy.invoke中執(zhí)行代碼,明顯感覺不正常,但又不知道原因???
2021/5/11再次調(diào)試發(fā)現(xiàn):
只要在IDEA中設(shè)置斷點(diǎn),比如在o.fun之后設(shè)置斷點(diǎn),也會出現(xiàn)次數(shù)不正常現(xiàn)象,但如果不設(shè)置斷點(diǎn)直接跑則一切正常。這種現(xiàn)象真的很奇怪,原因不明。
在Eclipse中設(shè)不設(shè)斷點(diǎn)一切現(xiàn)象都是正常的。
“InvocationHandler的invoke調(diào)用次數(shù)不正常是什么情況”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
網(wǎng)頁標(biāo)題:InvocationHandler的invoke調(diào)用次數(shù)不正常是什么情況
網(wǎng)頁地址:http://m.newbst.com/article16/jhesdg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、網(wǎng)站制作、全網(wǎng)營銷推廣、響應(yīng)式網(wǎng)站、建站公司、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)