本文主要和大家分享介紹了關于Java JDK 動態代理使用的相關內容,分享出來供大家參考學習,下面來一起看看詳細的介紹:
前言
代理是一種常用的設計模式,其目的就是為其他對象提供一個代理以控制對某個對象的訪問。代理類負責為委托類預處理消息,過濾消息并轉發消息,以及進行消息被委托類執行后的后續處理。
Spring AOP的實現對于接口來說就是使用的JDK的動態代理來實現的,而對于類的代理使用CGLIB來實現。
JDK的動態代理,就是在程序運行的過程中,根據被代理的接口來動態生成代理類的class文件,并加載運行的過程。
使用
首先創建接口
1
2
3
4
|
public interface Subject { void test(); } |
創建實現類
1
2
3
4
5
6
7
|
public class SubjectImpl implements Subject { @Override public void test() { System.out.println( "This is test method" ); } } |
創建InvocationHandler實現類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
public class SubjectInvocationHandler implements InvocationHandler { private Subject target; public SubjectInvocationHandler(Subject subject) { this .target = subject; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println( "before method!" ); Object result = method.invoke(target, args); System.out.println( "after method!" ); return result; } } |
最后調用:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
public class DynamicProxy { public static void main(String args[]) { Subject subject = new SubjectImpl(); Subject proxy = (Subject) Proxy.newProxyInstance(SubjectImpl. class .getClassLoader(), SubjectImpl. class .getInterfaces(), new SubjectInvocationHandler(subject)); proxy.test(); System.out.println(proxy); } } |
運行結果:
1
2
3
|
before method! This is test method after method! |
總結
1.通過實現InvocationHandler接口,在invoke方法中實現代理邏輯;
2.通過Proxy的newProxyInstance方法生成代理類,這里主要是根據被代理類的接口類型,通過反射創建代理類;
關于分析JDK動態代理這里有一篇很好的文章:Java JDK動態代理(AOP)的實現原理與使用詳析
好了,以上就是這篇文章的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:http://xdeveloper.cn/java-jdk-proxy/