概要
AOP的攔截功能是由java中的動態代理來實現的。說白了,就是在目標類的基礎上增加切面邏輯,生成增強的目標類(該切面邏輯或者在目標類函數執行之前,或者目標類函數執行之后,或者在目標類函數拋出異常時候執行。Spring中的動態代理是使用Cglib進行實現的。我們這里分析的是JDK中的動態代理實現機制。
下面我們通過例子快速了解JDK中的動態代理實現方式。
示例
需要代理的接口
1
2
3
|
public interface IHello { public void sayHello(); } |
需要代理的類
1
2
3
4
5
|
public class HelloImpl implements IHello { public void sayHello() { System.out.println(“Hello World…”); } } |
調用處理器實現類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
public class ProxyHandler implements InvocationHandler { private Object target; public ProxyHandler(Object target) { this .target = target; } public Object proxyInstance() { return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this ); } public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println(“aspect before … “); Object result = method.invoke( this .target, args); System.out.println(“aspect after … “); return result; } } |
測試類入口
1
2
3
4
5
6
7
|
public class Main { public static void main(String[] args) { ProxyHandler proxy = new ProxyHandler( new HelloImpl()); IHello hello = (IHello) proxy.proxyInstance(); hello.sayHello(); } } |
Proxy 源碼解析
1
|
newProxyInstance() 方法 |
省略了不關心的代碼
1
2
3
|
public static Object newProxyInstance(ClassLoader loader, Class c){ } |
如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://geek.csdn.net/news/detail/238661