java 中動(dòng)態(tài)代理詳解及實(shí)例
Java動(dòng)態(tài)代理相關(guān)
先來看靜態(tài)代理模式代碼:
package test;
public interface Subject
{
public void doSomething();
}
package test;
public class RealSubject implements Subject{
public void doSomething() {
System.out.println( "call doSomething()" );
}
}
package test;
public class SubjectProxy implements Subject {
Subject subimpl = new RealSubject();
public void doSomething() {
subimpl.doSomething();
}
}
package test;
public class TestProxy {
public static void main(String args[]) {
Subject sub = new SubjectProxy();
sub.doSomething();
}
}
剛開始我會(huì)覺得SubjectProxy定義出來純屬多余,直接實(shí)例化實(shí)現(xiàn)類完成操作不就結(jié)了嗎?后來隨著業(yè)務(wù)龐大,你就會(huì)知道,實(shí)現(xiàn)proxy類對真實(shí)類的封裝對于粒度的控制有著重要的意義。但是靜態(tài)代理這個(gè)模式本身有個(gè)大問題,如果類方法數(shù)量越來越多的時(shí)候,代理類的代碼量是十分龐大的。所以引入動(dòng)態(tài)代理來解決此類問題。
先看代碼:
package test;
public interface Subject
{
public void doSomething();
}
package test;
public class RealSubject implements Subject {
public void doSomething() {
System.out.println( "call doSomething()" );
}
}
package test;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ProxyHandler implements InvocationHandler {
private Object tar; //綁定委托對象,并返回代理類
public Object bind(Object tar) {
this.tar = tar; //綁定該類實(shí)現(xiàn)的所有接口,取得代理類
return Proxy.newProxyInstance(tar.getClass().getClassLoader(), tar.getClass().getInterfaces(), this);
}
public Object invoke(Object proxy , Method method , Object[] args)throws Throwable {
Object result = null;
//這里就可以進(jìn)行所謂的AOP編程了
//在調(diào)用具體函數(shù)方法前,執(zhí)行功能處理
result = method.invoke(tar,args);
//在調(diào)用具體函數(shù)方法后,執(zhí)行功能處理
return result;
}
}
public class TestProxy {
public static void main(String args[]) {
ProxyHandler proxy = new ProxyHandler(); //綁定該類實(shí)現(xiàn)的所有接口
Subject sub = (Subject) proxy.bind(new RealSubject());
sub.doSomething();
}
}
看完代碼,現(xiàn)在我來回答,動(dòng)態(tài)代理的作用是什么:
Proxy類的代碼量被固定下來,不會(huì)因?yàn)闃I(yè)務(wù)的逐漸龐大而龐大;
可以實(shí)現(xiàn)AOP編程,實(shí)際上靜態(tài)代理也可以實(shí)現(xiàn),總的來說,AOP可以算作是代理模式的一個(gè)典型應(yīng)用;
解耦,通過參數(shù)就可以判斷真實(shí)類,不需要事先實(shí)例化,更加靈活多變。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- 詳解java JDK 動(dòng)態(tài)代理類分析(java.lang.reflect.Proxy)
- Java動(dòng)態(tài)代理分析及理解
- java 中動(dòng)態(tài)代理(JDK,cglib)實(shí)例代碼
- java 動(dòng)態(tài)代理的方法總結(jié)
- 深度剖析java中JDK動(dòng)態(tài)代理機(jī)制
- Java 動(dòng)態(tài)代理深入理解
- JAVA動(dòng)態(tài)代理模式(從現(xiàn)實(shí)生活角度理解代碼原理)
- java 代理模式及動(dòng)態(tài)代理機(jī)制深入分析
- Java 動(dòng)態(tài)代理與CGLIB詳細(xì)介紹
- Java靜態(tài)代理和動(dòng)態(tài)代理總結(jié)
- 深入理解java動(dòng)態(tài)代理機(jī)制
- Java動(dòng)態(tài)代理分析及簡單實(shí)例
- java 1.8 動(dòng)態(tài)代理源碼深度分析
相關(guān)文章
關(guān)于Idea中的.properties文件顯示問題
這篇文章主要介紹了關(guān)于Idea中的.properties文件顯示問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
Java數(shù)據(jù)結(jié)構(gòu)最清晰圖解二叉樹前 中 后序遍歷
樹是一種重要的非線性數(shù)據(jù)結(jié)構(gòu),直觀地看,它是數(shù)據(jù)元素(在樹中稱為結(jié)點(diǎn))按分支關(guān)系組織起來的結(jié)構(gòu),很象自然界中的樹那樣。樹結(jié)構(gòu)在客觀世界中廣泛存在,如人類社會(huì)的族譜和各種社會(huì)組織機(jī)構(gòu)都可用樹形象表示2022-01-01
通過Maven進(jìn)行jedis連接redis的實(shí)現(xiàn)
這篇文章主要介紹了通過Maven進(jìn)行jedis連接redis的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
使用SpringMVC返回json字符串的實(shí)例講解
下面小編就為大家分享一篇使用SpringMVC返回json字符串的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
spring-boot-maven-plugin未指定版本導(dǎo)致的編譯錯(cuò)誤問題
這篇文章主要介紹了spring-boot-maven-plugin未指定版本導(dǎo)致的編譯錯(cuò)誤問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Java分布式學(xué)習(xí)之Kafka消息隊(duì)列
Kafka是由Apache軟件基金會(huì)開發(fā)的一個(gè)開源流處理平臺(tái),由Scala和Java編寫。Kafka是一種高吞吐量的分布式發(fā)布訂閱消息系統(tǒng),它可以處理消費(fèi)者在網(wǎng)站中的所有動(dòng)作流數(shù)據(jù)2022-07-07
SpringBoot通過Filter實(shí)現(xiàn)整個(gè)項(xiàng)目接口的SQL注入攔截詳解
這篇文章主要介紹了SpringBoot通過Filter實(shí)現(xiàn)整個(gè)項(xiàng)目接口的SQL注入攔截詳解,SQL注入是比較常見的網(wǎng)絡(luò)攻擊方式之一,在客戶端在向服務(wù)器發(fā)送請求的時(shí)候,sql命令通過表單提交或者url字符串拼接傳遞到后臺(tái)持久層,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令,需要的朋友可以參考下2023-12-12
淺談spring和spring MVC的區(qū)別與關(guān)系
下面小編就為大家?guī)硪黄獪\談spring和spring MVC的區(qū)別與關(guān)系。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04

