Java動態代理其實寫日常業務代碼是不常用的,但在框架層一起RPC框架的客戶端是非常常見及重要的。spring的核心思想aop的底層原理實現就使用到了java的動態代理技術。
使用代理可以實現對象的遠程調用以及aop的實現。
java的動態代理的實現,主要依賴InvoctionHandler(接口)和Proxy(類)這兩個。
下面是一個例子
實現的代理的一般需要有個接口
1
2
3
4
5
6
7
8
9
|
package com.yasin.ProxyLearn; public interface IStudy { public void learn(); public String getKonwledge(); } |
該接口的實現的類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
package com.yasin.ProxyLearn; public class Study implements IStudy{ public void learn() { System.out.println( "我要開始學習了!" ); } public String getKonwledge() { return "Java真的強" ; } } |
代理類,該類需要實現InvacationHandler接口
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
package com.yasin.ProxyLearn; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; public class StudyProxy implements InvocationHandler{ //真實要被代理的對象 private Object study; public StudyProxy(Object study){ this .study=study; } /** * 當被代理對象執行自己的方法時,便會執行這個方法 */ public Object invoke(Object object, Method method, Object[] args) throws Throwable { Object obj= null ; System.out.println( "代理執行前我可以執行一些操作" ); //執行被代理對象的方法 obj = method.invoke(study, args); System.out.println( "代理執行后我還可以執行一些操作" ); return obj; } } |
測試類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
package com.yasin.JavaLearn; import java.lang.reflect.Field; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; import org.apache.log4j.xml.DOMConfigurator; import com.yasin.ProxyLearn.IStudy; import com.yasin.ProxyLearn.Study; import com.yasin.ProxyLearn.StudyProxy; /** * Hello world! * */ public class App { public static void main(String[] args) { IStudy study = new Study(); InvocationHandler handler = new StudyProxy(study); IStudy proxyStudy =(IStudy)Proxy.newProxyInstance(Thread.currentThread().getContextClassLoader(), new Class[] {IStudy. class }, handler); proxyStudy.learn(); System.out.println(proxyStudy.getKonwledge()); } } |
以上就是java動態代理的基礎使用,在spring aop及rpc的遠程服務端的實現要比這復雜下,以后會在深入探討的。
如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/u013592964/article/details/72853424