Java完成靜態署理。本站提示廣大學習愛好者:(Java完成靜態署理)文章只能為提供參考,不一定能成為您想要的結果。以下是Java完成靜態署理正文
Java靜態署理類位於java.lang.reflect包下,普通重要觸及到以下兩個類:
(1)InvocationHandler:該接口中僅界說了一個辦法
public object invoke(Object obj,Method method, Object[] args)
在現實應用時,第一個參數obj普通是指署理類,method是被署理的辦法,如上例中的request(),args為該辦法的參數數組。 這個籠統辦法在署理類中靜態完成。
(2)Proxy:該類即為靜態署理類,感化相似於上例中的ProxySubject,個中重要包括以下內容protected Proxy(InvocationHandler h):結構函數,用於給外部的h賦值。
static Class getProxyClass (ClassLoader loader, Class[] interfaces)
取得一個署理類,個中loader是類裝載器,interfaces是真實類所具有的全體接口的數組。
static Object newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h)
前往署理類的一個實例,前往後的署理類可以看成被署理類使 用(可以使用被署理類的在Subject接口中聲明過的辦法)
所謂Dynamic Proxy是如許一種class:它是在運轉時生成的class,在生成它時你必需 供給一組interface給它,然後該class就傳播鼓吹它完成了這些 interface。你固然可以把 該class的實例看成這些interface中的任何一個來用。固然,這個Dynamic Proxy其實 就是一個 Proxy,它不會替你作本質性的任務,在生成它的實例時你必需供給一個handler,由它 接收現實的任務。
在應用靜態署理類時,我們必需完成InvocationHandler接口:
拜見法式 Subject.java
拜見法式 RealSubject.java
拜見法式 DynamicSubject.java
拜見法式 Client.java
package com.langsin.dynamicproxy;
//籠統腳色(之前是籠統類,此處應改成接口):
public interface Subject
{
abstract public void request();
}
package com.langsin.dynamicproxy;
//詳細腳色
public class RealSubject implements Subject
{
public RealSubject()
{
}
public void request()
{
System.out.println("From real subject.");
}
}
package com.langsin.dynamicproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
//署理處置器
/**
* 該署理類的外部屬性為Object類,現實應用時經由過程該類的結構函數DynamicSubject(Object obj)對其賦值;
* 另外,在該類還完成了invoke辦法,該辦法中的 method.invoke(sub,args);
* 其實就是挪用被署理對象的將要被履行的辦法,辦法參數sub是現實的被署理對象,
* args為履行被署理對象響應操作所需的參數。
* 經由過程靜態署理類,我們可以在挪用之前或以後履行一些相干操作
*/
public class DynamicSubject implements InvocationHandler
{
private Object sub;
public DynamicSubject()
{
}
public DynamicSubject(Object obj)
{
sub = obj;
}
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable
{
System.out.println("before calling " + method);
method.invoke(sub, args);
System.out.println("after calling " + method);
return null;
}
}
package com.langsin.dynamicproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;
//客戶端
public class Client
{
static public void main(String[] args) throws Throwable
{
RealSubject rs = new RealSubject(); // 在這裡指定被署理類
InvocationHandler ds = new DynamicSubject(rs);
Class<?> cls = rs.getClass();
// 以下是一次性生成署理
Subject subject = (Subject) Proxy.newProxyInstance(
cls.getClassLoader(), cls.getInterfaces(), ds);
subject.request();
}
}
實例2:
package com.langsin.dynamicproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.List;
import java.util.Vector;
public class VectorProxy implements InvocationHandler
{
private Object proxyobj;
public VectorProxy(Object obj){
proxyobj = obj;
}
public static Object factory(Object obj){
Class<?> cls = obj.getClass();
return Proxy.newProxyInstance(cls.getClassLoader(), cls.getInterfaces(), new VectorProxy(obj));
}
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable{
System.out.println("before calling " + method);
if (args != null){
for (int i = 0; i < args.length; i++){
System.out.println(args[i] + "");
}
}
Object object = method.invoke(proxyobj, args);
System.out.println("after calling " + method);
return object;
}
@SuppressWarnings("unchecked")
public static void main(String[] args){
List<String> v = (List<String>) factory(new Vector<String>(10));
v.add("New");
v.add("York");
System.out.println(v);
v.remove(0);
System.out.println(v);
}
}
實例3、
package com.langsin.dynamicproxy;
public interface Foo{
void doAction();
}
package com.langsin.dynamicproxy;
public class FooImpl implements Foo{
public FooImpl(){
}
public void doAction(){
System.out.println("in FooImp1.doAction()");
}
}
package com.langsin.dynamicproxy;
public class FooImpl2 implements Foo{
public FooImpl2(){
}
public void doAction(){
System.out.println("in FooImp2.doAction()");
}
}
package com.langsin.dynamicproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class CommonInvocationHandler implements InvocationHandler{
// 靜態履行對象,須要回調的對象
private Object target;
// 支撐結構子打針
public CommonInvocationHandler(){
}
// 支撐結構子打針
public CommonInvocationHandler(Object target){
setTarget(target);
}
/**
*
* 采取setter辦法打針
*
* @param target
*
*/
public void setTarget(Object target){
this.target = target;
}
/**
*
* 挪用proxy中指定的辦法method,並傳入參數列表args
*
* @param proxy
* 署理類的類型,例如界說對應method的署理接口
*
* @param method
* 被署理的辦法
*
* @param args
* 挪用被署理辦法的參數
*
* @return
*
* @throws java.lang.Throwable
*
*/
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable{
return method.invoke(target, args);
}
}
package com.langsin.dynamicproxy;
import java.lang.reflect.Proxy;
public class Demo{
public static void main(String[] args){
// 1.通用的靜態署理完成
CommonInvocationHandler handler = new CommonInvocationHandler();
Foo f;
// 2.接話柄現1
handler.setTarget(new FooImpl());
// 辦法參數解釋:署理類、署理類完成的接口列表、署理類的處置器
// 聯系關系署理類、署理類中接口辦法、處置器,現代理類中接口辦法被挪用時,會主動分發隨處理器的invoke辦法
// 假如署理類沒有完成指定接口列表,會拋出不法參數異常
f = (Foo) Proxy.newProxyInstance(Foo.class.getClassLoader(),
new Class[] { Foo.class },
handler);
f.doAction();
// 3.接話柄現2
handler.setTarget(new FooImpl2());
f = (Foo) Proxy.newProxyInstance(Foo.class.getClassLoader(),
new Class[] { Foo.class },
handler);
f.doAction();
}
}
因為自己文彩無限,所以年夜部門內容都是代碼,還請年夜家原諒^_^