InvocationHandler实现类中的invoke方法为什么会被自动执行
一:首先需要明確的是動態(tài)代理中,InvocationHandler實現(xiàn)類并不是代理類,只是代理類與被代理類的一個中間類,該類只是用來做功能增強的,這也是動態(tài)代理能夠解耦的原因
二:動態(tài)代理中的代理類是通過Proxy.newInstance方法,即反射生成代理類實例的,該代理類中有一個與被代理方法同名的成員方法,而該成員方法的實現(xiàn)實際就是調用了InvocationHandler實現(xiàn)類的invoke方法,即通過代理類實例調用該成員方法實際調用的是InvocationHandler實現(xiàn)類的invoke方法。而InvocationHandler實現(xiàn)類中的invoke方法就是用來做功能增強的。進而完成了方法的動態(tài)代理。
//實現(xiàn)InvocationHandler接口,完成功能的增強public Class ProxyA implements InvocationHandler{@Overridepublic Object invoke(Object proxy,Method method,Object[] args){//邏輯增強實現(xiàn)//執(zhí)行被代理方法method.invoke()}//生成代理類。在InvocationHandler實現(xiàn)類的構造函數(shù)當中創(chuàng)建代理類實例,該代理類實例會自動生成一個 //與被代理方法同名的方法,在該方法中實際會調用實現(xiàn)類的invoke()方法public ProxyA(){return Proxy.newProxyInstance(相應參數(shù))} }//調用 public Test{ //通過中間類ProxyA動態(tài)創(chuàng)建出代理類(實際調用的是Proxy.newProxyInstance())public static void main(Stirng args[]){}T proxy = new ProxyA()proxy.xxx() }三:另外,靜態(tài)代理與動態(tài)代理的區(qū)別之一也體現(xiàn)在這里。靜態(tài)代理與動態(tài)代理的不同之一就是代理類的創(chuàng)建方法不同,前者是直接手動生成的,后者則是通過反射,運行時動態(tài)生成的(代理模式的基本邏輯是一樣的)
四:靜態(tài)代理與動態(tài)代理的區(qū)別詳細說明
? ? ? ? 靜態(tài)代理會把代理類與被代理類一一綁定,代理類需要持有被代理類的對象引用,即使要再增加一個一模一樣的功能時,依然要再創(chuàng)建出一個代理類來對該功能進行增強,也就是所謂的代理一百個類,就要創(chuàng)建一百個代理類
? ? ? ? 而動態(tài)代理,由于使用的是反射技術,代理類是不需要持有被代理類的對象的(實質代理類都不是自己手動創(chuàng)建的),運行時生成的代理類通過InvocationHandler實現(xiàn)類,進而拿到需要被代理的方法。如果增強同一接口的不同實現(xiàn)類,但是增強的功能是一樣的話,jdk動態(tài)代根本不需要改動任何代碼,即可完成功能的增強。只要InvocationHandler依賴的是被代理的接口即可。當然靜態(tài)代理一樣可以通過依賴接口來進行解耦,但是動態(tài)代理與靜態(tài)代理的核心區(qū)別是代理類與被代理類是否直接依賴,當要給接口的不同方法增強相同的功能時,靜態(tài)代理模式依然是要改動代理類的。
最后:附上后端技術交流圈,歡迎各位大佬入圈交流.......(先添加好友后拉群,添加好友時請備注:小白不黑)
?
總結
以上是生活随笔為你收集整理的InvocationHandler实现类中的invoke方法为什么会被自动执行的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java和springboot开发的养老
- 下一篇: 我的十年编程路 2017年篇