本篇內(nèi)容介紹了“InvocationHandler的invoke調(diào)用次數(shù)不正常是什么情況”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)建站是一家專注于網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)和樂山服務(wù)器托管的網(wǎng)絡(luò)公司,有著豐富的建站經(jīng)驗(yàn)和案例。
大概意思就是:同一份動(dòng)態(tài)代碼實(shí)驗(yàn)代碼,放在Eclipse中測(cè)試一切正常,但放在IDEA 中的springboot項(xiàng)目中測(cè)試時(shí)就不正常。
動(dòng)態(tài)代理實(shí)驗(yàn),一個(gè)接口:
public interface DestInterface {
void fun(String msg);
}
這個(gè)接口的實(shí)現(xiàn)類:
public class DestClass implements DestInterface {
public void fun(String msg) {
System.out.println("DestClass.fun "+ msg);
}
}
一個(gè)InvocationHandler接口的實(shí)現(xiàn)類:
public class DynamicProxy implements InvocationHandler {
private Object object;//要代理的真正對(duì)象
public DynamicProxy(Object obj) //構(gòu)造并傳遞真正的對(duì)象
{
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í)行,不明白為什么會(huì)這樣
Object obj = method.invoke(object,args);//出現(xiàn)類不匹配的原因是:主程序中InvocationHandler invocationHandler = new DynamicProxy(someservice);
//其實(shí)在InvocationHandler實(shí)例化對(duì)象的時(shí)候,傳入的是真正的要在其上執(zhí)行函數(shù)的對(duì)象,這個(gè)對(duì)象所在類應(yīng)該繼承了一個(gè)或多個(gè)接口,當(dāng)然這些接口在Proxy.newInstance
// 創(chuàng)建代理對(duì)象的時(shí)候?qū)⑦@些接口的Class傳入。也就是說new InvocationHandler對(duì)象的時(shí)候參數(shù)應(yīng)該是目標(biāo)類的對(duì)象,此例是DestInterface的實(shí)現(xiàn)類的對(duì)象
System.out.println("after proxy vaue="+obj);
return null;
}
}
具體要想使用動(dòng)態(tài)代理對(duì)象的代碼如下:
DestInterface destInterface = new DestClass();//真正的目標(biāo)對(duì)象 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項(xiàng)目中顯示如下:
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)試時(shí)發(fā)現(xiàn)當(dāng)執(zhí)行完P(guān)roxy.newInstance這一句之后居然發(fā)現(xiàn)會(huì)進(jìn)入DymicProxy.invoke中執(zhí)行代碼,明顯感覺不正常,但又不知道原因???
2021/5/11再次調(diào)試發(fā)現(xiàn):
只要在IDEA中設(shè)置斷點(diǎn),比如在o.fun之后設(shè)置斷點(diǎn),也會(huì)出現(xiàn)次數(shù)不正?,F(xiàn)象,但如果不設(shè)置斷點(diǎn)直接跑則一切正常。這種現(xiàn)象真的很奇怪,原因不明。
在Eclipse中設(shè)不設(shè)斷點(diǎn)一切現(xiàn)象都是正常的。
“InvocationHandler的invoke調(diào)用次數(shù)不正常是什么情況”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!