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