詳解Java動態(tài)代理的實現(xiàn)及應(yīng)用
詳解Java動態(tài)代理的實現(xiàn)及應(yīng)用
Java動態(tài)代理其實寫日常業(yè)務(wù)代碼是不常用的,但在框架層一起RPC框架的客戶端是非常常見及重要的。spring的核心思想aop的底層原理實現(xiàn)就使用到了java的動態(tài)代理技術(shù)。
使用代理可以實現(xiàn)對象的遠程調(diào)用以及aop的實現(xiàn)。
java的動態(tài)代理的實現(xiàn),主要依賴InvoctionHandler(接口)和Proxy(類)這兩個。
下面是一個例子
實現(xiàn)的代理的一般需要有個接口
package com.yasin.ProxyLearn;
public interface IStudy {
public void learn();
public String getKonwledge();
}
該接口的實現(xiàn)的類
package com.yasin.ProxyLearn;
public class Study implements IStudy{
public void learn() {
System.out.println("我要開始學(xué)習(xí)了!");
}
public String getKonwledge() {
return "Java真的強";
}
}
代理類,該類需要實現(xiàn)InvacationHandler接口
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;
}
/**
* 當(dāng)被代理對象執(zhí)行自己的方法時,便會執(zhí)行這個方法
*/
public Object invoke(Object object, Method method, Object[] args) throws Throwable {
Object obj=null;
System.out.println("代理執(zhí)行前我可以執(zhí)行一些操作");
//執(zhí)行被代理對象的方法
obj = method.invoke(study, args);
System.out.println("代理執(zhí)行后我還可以執(zhí)行一些操作");
return obj;
}
}
測試類
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動態(tài)代理的基礎(chǔ)使用,在spring aop及rpc的遠程服務(wù)端的實現(xiàn)要比這復(fù)雜下,以后會在深入探討的。
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SpringCloud Zuul在何種情況下使用Hystrix及問題小結(jié)
這篇文章主要介紹了SpringCloud Zuul在何種情況下使用Hystrix 及問題小結(jié),感興趣的朋友跟隨小編一起看看吧2018-11-11
Maven?繼承父工程時的relativePath標(biāo)簽詳細解析
這篇文章主要介紹了Maven?繼承父工程時的relativePath標(biāo)簽解析,通過本文學(xué)習(xí)你需要注意子模塊想要用父模塊pom中的版本,請注意配置relativePath屬性,需要的朋友可以參考下2022-12-12
IDEA如何自動生成serialVersionUID的設(shè)置
這篇文章主要介紹了IDEA如何自動生成 serialVersionUID 的設(shè)置,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
詳解SpringBoot中添加@ResponseBody注解會發(fā)生什么
這篇文章主要介紹了詳解SpringBoot中添加@ResponseBody注解會發(fā)生什么,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11

