您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么實(shí)現(xiàn)靜動(dòng)態(tài)代理模式,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
1.靜態(tài)代理模式
使用場(chǎng)合:
為其他對(duì)象提供一種代理以控制對(duì)這個(gè)對(duì)象的訪問。在某些情況下,一個(gè)客戶不想或者不能直接引用另一個(gè)對(duì)象,而代理對(duì)象可以在客戶端和目標(biāo)對(duì)象之間起到中介的作用。
涉及的角色:
抽象角色:
聲明真實(shí)對(duì)象和代理對(duì)象的共同接口;
代理角色:
代理對(duì)象角色內(nèi)部含有對(duì)真實(shí)對(duì)象的引用,從而可以操作真實(shí)對(duì)象,同時(shí)代理對(duì)象提供與真實(shí)對(duì)象相同的接口以便在任何時(shí)刻都能代替真實(shí)對(duì)象。同時(shí),代理對(duì)象可以在執(zhí)行真實(shí)對(duì)象操作時(shí),附加其他的操作,相當(dāng)于對(duì)真實(shí)對(duì)象進(jìn)行封裝。
真實(shí)角色:
代理角色所代表的真實(shí)對(duì)象,是我們最終要引用的對(duì)象。
***的老師是代碼,下面是本人敲的一個(gè)靜態(tài)代理代碼示例
Java代碼 收藏代碼
package com; /** * 車站接口-【抽象角色】 * * @author abing * */ interface Station { void sellTicks();// 賣票 void transport();// 運(yùn)輸乘客 } /** * 火車站實(shí)現(xiàn)類-【具體角色】 * * @author abing * */ class TrainStationImpl implements Station { @Override public void sellTicks() { System.out.println("TrainStation sell tickets"); } @Override public void transport() { System.out.println("TrainStation transport passenger"); } } /** * 該類做為火車站的一個(gè)代理直接供客戶端調(diào)用-【代理角色】 * * @author abing * */ class StationProxy implements Station { Station sta = new TrainStationImpl(); @Override public void sellTicks() { sta.sellTicks();//代理類中調(diào)用真實(shí)角色的方法。 } public void otherOperate() { System.out.println("do some other things..."); } @Override public void transport() { System.out.println("StationProxy can not transport"); } } /** * 客戶端測(cè)試類 * * @author abing * */ public class StaticProxyDemo { public static void main(String[] args) { Station station = new StationProxy();//客戶端直接操作代理類,避免了客戶端與真實(shí)類的直接交涉 station.sellTicks(); } }
2.動(dòng)態(tài)代理模式
靜態(tài)代理模式中,真實(shí)角色必須是事先已經(jīng)存在的,并將其作為代理對(duì)象的內(nèi)部屬性,并且真實(shí)角色必須對(duì)應(yīng)一個(gè)代理角色,如果大量使用會(huì)導(dǎo)致類的急劇膨脹。那么,如果事先并不知道真實(shí)角色,該如何使用代理呢?這個(gè)問題可以通過Java的動(dòng)態(tài)代理類來解決。
動(dòng)態(tài)代理必需用到以下兩個(gè)類。
(1). Interface InvocationHandler:該接口中僅定義了一個(gè)方法Object:invoke(Object obj,Method method, Object[] args)。用于完成真實(shí)角色中方法的調(diào)用。(2).Proxy:該類即為動(dòng)態(tài)代理類,作用類似于靜態(tài)代理模式的代理類
***的老師是代碼,下面是本人敲的一個(gè)動(dòng)態(tài)代理代碼示例
Java代碼 收藏代碼
package com.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; /** * 車站接口-【抽象角色】 * @author abing * */ interface Station { void sellTicks();// 賣票 } /** * 火車站實(shí)現(xiàn)類-【具體角色】 * @author abing * */ class TrainStationImpl implements Station { @Override public void sellTicks() { System.out.println("TrainStation sell tickets"); } } /** * 使用動(dòng)態(tài)代理模式必須實(shí)現(xiàn)InvocationHandler接口,該接口中僅定義了一個(gè)方法: * invoke(Object obj,Method method, Object[] args)。 * 在實(shí)際使用時(shí),***個(gè)參數(shù)obj一般是指代理類,method是被代理的方法,args為該方法的參數(shù)數(shù)組 * * @author abing * */ class InvocationHandlerImpl implements InvocationHandler { Object proxyobj; public InvocationHandlerImpl(Object object) { this.proxyobj = object; } @Override public Object invoke(Object obj, Method method, Object[] args) throws Throwable { System.out.println("start doing ........."); method.invoke(proxyobj, args);//調(diào)用被代理對(duì)象proxyobj的方法method,傳入一個(gè)參數(shù)組args System.out.println("stop doing ........."); return null; } } /** * 客戶端測(cè)試類 * @author abing * */ public class DynamicProxyDemo { public static void main(String[] args) { Station stationImpl = new TrainStationImpl();//將要被代理的真實(shí)對(duì)象 /** * 動(dòng)態(tài)代理就好處在這里,不管這里是要代理什么對(duì)象,I * nvocationHandlerImpl與Proxy中代碼都不必改變, * 都是用下面同樣的方式去產(chǎn)生代理對(duì)象 */ InvocationHandler handler = new InvocationHandlerImpl(stationImpl);//用InvocationHandler的實(shí)現(xiàn)類包裝真實(shí)的被代理角色 ClassLoader loader = handler.getClass().getClassLoader();//獲取當(dāng)期那java程序的類裝在器Classloadler Class<?>[] interfaces = stationImpl.getClass().getInterfaces();//獲取被代理角色實(shí)現(xiàn)的所有接口 /** * Proxy類是動(dòng)態(tài)代理模式涉及到的另一個(gè)重要的類,該類即為動(dòng)態(tài)代理類,作用類似于靜態(tài)代理模式中的代理類StationProxy, * 它有一個(gè)重要方法tatic Object newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h):返回代理類的一個(gè)實(shí)例。 * 其中l(wèi)oader是類裝載器,interfaces是真實(shí)類所擁有的全部接口的數(shù)組,傳遞此參數(shù)以使產(chǎn)生的代理對(duì)象可以當(dāng)做真實(shí)類任意實(shí)現(xiàn)接口的子類來用, * h是調(diào)用處理器InvocationHandler。 */ Station station = (Station) Proxy.newProxyInstance(loader, interfaces,handler); station.sellTicks();//將會(huì)去執(zhí)行DynamicProxy的invoke方法,完成對(duì)目標(biāo)對(duì)象方法的調(diào)用 } }
關(guān)于Java中怎么實(shí)現(xiàn)靜動(dòng)態(tài)代理模式就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。