這篇文章主要介紹了Java怎么實(shí)現(xiàn)動(dòng)態(tài)代理模式,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
為新?lián)岬鹊貐^(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及新?lián)峋W(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、新?lián)峋W(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
具體如下:
前面介紹了靜態(tài)代理模式,動(dòng)態(tài)代理比靜態(tài)代理模式更加強(qiáng)大。它能在程序運(yùn)行時(shí)動(dòng)態(tài)的生成代理對(duì)象。所謂動(dòng)態(tài)代理類是在運(yùn)行時(shí)生成的class,在生成它時(shí),你必須提供一組interface給它,則動(dòng)態(tài)代理類就宣稱它實(shí)現(xiàn)了這些interface。當(dāng)然,動(dòng)態(tài)代理類就充當(dāng)一個(gè)代理,你不要企圖它會(huì)幫你干實(shí)質(zhì)性的工作,在生成它的實(shí)例時(shí)你必須提供一個(gè)handler,由它接管實(shí)際的工作。
動(dòng)態(tài)代理的角色和靜態(tài)代理的角色一樣:
① 抽象角色:真實(shí)對(duì)象和代理對(duì)象的共同接口。其中聲明真實(shí)對(duì)象和代理對(duì)象需要做的事。
② 真實(shí)角色:實(shí)現(xiàn)抽象角色,定義真實(shí)角色所要實(shí)現(xiàn)的業(yè)務(wù)邏輯,供代理角色調(diào)用。
③ 動(dòng)態(tài)代理角色:需要實(shí)現(xiàn)InvocationHandler接口,并且實(shí)現(xiàn)其中的invoke方法。動(dòng)態(tài)代理覺得持有一個(gè)Object類型引用,這個(gè)表示需要?jiǎng)討B(tài)代理的角色。定義為Object類型,表示可動(dòng)態(tài)代理任何類型的對(duì)象。
以下給出一個(gè)簡(jiǎn)單的動(dòng)態(tài)代理模式的簡(jiǎn)單的代碼實(shí)例:
1. 抽象角色:真實(shí)對(duì)象和代理對(duì)象的共同接口。其中聲明真實(shí)對(duì)象和代理對(duì)象需要做的事。
package com.tydic.dynamicproxy; public interface Subject { public void request(); }
2. 真實(shí)角色:需要實(shí)現(xiàn)抽象角色,是被代理的對(duì)象。
package com.tydic.dynamicproxy; public class RealSubject implements Subject { @Override public void request() { System.out.println("from real subject!"); } }
3. 動(dòng)態(tài)代理角色:需要實(shí)現(xiàn)InvocationHandler接口,并重寫接口里面的invoke方法public Object invoke(Object proxy, Method method, Object[] args)
。invoke方法有三個(gè)參數(shù)。參數(shù)proxy指代理類,method表示被代理的方法,args為method中的參數(shù)數(shù)組,返回值Object為代理實(shí)例的方法調(diào)用返回的值。這個(gè)抽象方法在代理類中動(dòng)態(tài)實(shí)現(xiàn)。
package com.tydic.dynamicproxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; public class DynamicSubject implements InvocationHandler { private Object sub;//被代理的對(duì)象 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. 編寫客戶端代碼:需要用到一個(gè)Proxy類。Proxy類所有動(dòng)態(tài)代理類的父類,提供用于創(chuàng)建動(dòng)態(tài)代理類和實(shí)例的靜態(tài)方法。Proxy類有一個(gè)靜態(tài)方法public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h)
。第一個(gè)參數(shù)表示動(dòng)態(tài)代理類的類加載器,第二個(gè)是動(dòng)態(tài)代理類應(yīng)該要實(shí)現(xiàn)的接口的Class數(shù)組,第三個(gè)參數(shù)是InvocationHandler 對(duì)象,當(dāng)動(dòng)態(tài)代理調(diào)用需要代理的方法時(shí),InvocationHandler 對(duì)象的invoke方法會(huì)得到調(diào)用。
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); //動(dòng)態(tài)的生成代理對(duì)象 Subject sub = (Subject) Proxy.newProxyInstance(DynamicSubject.class.getClassLoader(), subject.getClass().getInterfaces(), handle); sub.request();//實(shí)際是handle的invoke方法得到了調(diào)用 } }
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Java怎么實(shí)現(xiàn)動(dòng)態(tài)代理模式”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
文章名稱:Java怎么實(shí)現(xiàn)動(dòng)態(tài)代理模式
文章出自:http://chinadenli.net/article24/jiipje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、小程序開發(fā)、品牌網(wǎng)站設(shè)計(jì)、全網(wǎng)營(yíng)銷推廣、用戶體驗(yàn)、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)