程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java完成靜態署理

Java完成靜態署理

編輯:關於JAVA

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();
    }
}

因為自己文彩無限,所以年夜部門內容都是代碼,還請年夜家原諒^_^

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved