本文是在學習如下博文的一些總結。
http://zhangjunhd.blog.51cto.com/113473/69996
代理模式:
增加了一個中介,利用此中介調用實作類別的邏輯,對外只公布中介,外部代碼不能直接存取實作類別。
應用情境:
當不希望將實作類別完全暴露給調用方時,可以實現代理模式。調用方直接調用代理,而代理調用實作類別。
規則:
為保證對調用者透明,代理類和實作類別一般都實現同一個介面,這樣,調用者就感覺直接調用了實作類別。
JAVA 的Proxy類
為實現代理模式,java提供了一個類Proxy。
Proxy可以根據相應介面,產生相應的代理類,而後得到代理執行個體,此代理執行個體被調用後將調用InvocationHandler 。
所以InvocationHandler 需要實現具體的執行邏輯。
以下對Proxy的重要方法做一些解析。
1)public static Class<?> getProxyClass(ClassLoader loader,
Class<?>... interfaces)
throws IllegalArgumentException
此方法主要實現下列邏輯
- · 動態生產class,此class實現了interfaces數組所有的介面,且有一個構造方法,僅有一個入參為InvocationHandler類型。
- · 使用loader載入此class
- · 最後,返回Class對象。
2)
public static Object newProxyInstance(ClassLoader loader,
Class<?>[] interfaces,
InvocationHandler h)
throws IllegalArgumentException
此方法實現邏輯如下
- · 首先調用getProxyClass(),獲得了一個Class對象 Proxyclass,
- · Constructor ProxyConstructor=Proxyclass.getConstructor(new Class[] { InvocationHandler.class });//擷取Constructor
- · Object proxy2= (Object) ProxyConstructor.newInstance(new InvocationHandler [ ] { h}); //利用Constructor