本文實例講述了java設計模式之動態代理模式。分享給大家供大家參考,具體如下:
前面介紹了靜態代理模式,動態代理比靜態代理模式更加強大。它能在程序運行時動態的生成代理對象。所謂動態代理類是在運行時生成的class,在生成它時,你必須提供一組interface給它,則動態代理類就宣稱它實現了這些interface。當然,動態代理類就充當一個代理,你不要企圖它會幫你干實質性的工作,在生成它的實例時你必須提供一個handler,由它接管實際的工作。
動態代理的角色和靜態代理的角色一樣:
① 抽象角色:真實對象和代理對象的共同接口。其中聲明真實對象和代理對象需要做的事。
② 真實角色:實現抽象角色,定義真實角色所要實現的業務邏輯,供代理角色調用。
③ 動態代理角色:需要實現invocationhandler接口,并且實現其中的invoke方法。動態代理覺得持有一個object類型引用,這個表示需要動態代理的角色。定義為object類型,表示可動態代理任何類型的對象。
以下給出一個簡單的動態代理模式的簡單的代碼實例:
1. 抽象角色:真實對象和代理對象的共同接口。其中聲明真實對象和代理對象需要做的事。
1
2
3
4
|
package com.tydic.dynamicproxy; public interface subject { public void request(); } |
2. 真實角色:需要實現抽象角色,是被代理的對象。
1
2
3
4
5
6
7
|
package com.tydic.dynamicproxy; public class realsubject implements subject { @override public void request() { system.out.println( "from real subject!" ); } } |
3. 動態代理角色:需要實現invocationhandler接口,并重寫接口里面的invoke方法public object invoke(object proxy, method method, object[] args)
。invoke方法有三個參數。參數proxy指代理類,method表示被代理的方法,args為method中的參數數組,返回值object為代理實例的方法調用返回的值。這個抽象方法在代理類中動態實現。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
package com.tydic.dynamicproxy; import java.lang.reflect.invocationhandler; import java.lang.reflect.method; public class dynamicsubject implements invocationhandler { private object sub; //被代理的對象 public dynamicsubject(object obj) { this .sub = obj; } @override public object invoke(object proxy, method method, object[] args) throws throwable { system.out.println( "before calling:" + method); //可以在被代理的方法前后添加功能 method.invoke(sub, args); system.out.println( "after calling:" + method); return null ; } } |
4. 編寫客戶端代碼:需要用到一個proxy類。proxy類所有動態代理類的父類,提供用于創建動態代理類和實例的靜態方法。proxy類有一個靜態方法public static object newproxyinstance(classloader loader, class<?>[] interfaces, invocationhandler h)
。第一個參數表示動態代理類的類加載器,第二個是動態代理類應該要實現的接口的class數組,第三個參數是invocationhandler 對象,當動態代理調用需要代理的方法時,invocationhandler 對象的invoke方法會得到調用。
1
2
3
4
5
6
7
8
9
10
11
|
package com.tydic.dynamicproxy; import java.lang.reflect.proxy; public class client { public static void main(string[] args) { subject subject = new realsubject(); dynamicsubject handle = new dynamicsubject(subject); //動態的生成代理對象 subject sub = (subject) proxy.newproxyinstance(dynamicsubject. class .getclassloader(), subject.getclass().getinterfaces(), handle); sub.request(); //實際是handle的invoke方法得到了調用 } } |
希望本文所述對大家java程序設計有所幫助。
原文鏈接:https://blog.csdn.net/zw19910924/article/details/45228125