国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - Java實(shí)現(xiàn)動(dòng)態(tài)代理

Java實(shí)現(xiàn)動(dòng)態(tài)代理

2019-12-10 13:52hebedich JAVA教程

本文給大家介紹的是java使用動(dòng)態(tài)代理類實(shí)現(xiàn)動(dòng)態(tài)代理的方法和示例,這里推薦給大家,有需要的小伙伴參考下吧

Java動(dòng)態(tài)代理類位于java.lang.reflect包下,一般主要涉及到以下兩個(gè)類: 
(1)InvocationHandler:該接口中僅定義了一個(gè)方法
        public object invoke(Object obj,Method method, Object[] args)
        在實(shí)際使用時(shí),第一個(gè)參數(shù)obj一般是指代理類,method是被代理的方法,如上例中的request(),args為該方法的參數(shù)數(shù)組。 這個(gè)抽象方法在代理類中動(dòng)態(tài)實(shí)現(xiàn)。

(2)Proxy:該類即為動(dòng)態(tài)代理類,作用類似于上例中的ProxySubject,其中主要包含以下內(nèi)容protected Proxy(InvocationHandler h):構(gòu)造函數(shù),用于給內(nèi)部的h賦值。 
        static Class getProxyClass (ClassLoader loader, Class[] interfaces)
        獲得一個(gè)代理類,其中l(wèi)oader是類裝載器,interfaces是真實(shí)類所擁有的全部接口的數(shù)組。

        static Object newProxyInstance(ClassLoader loader, Class[] interfaces, InvocationHandler h)
        返回代理類的一個(gè)實(shí)例,返回后的代理類可以當(dāng)作被代理類使    用(可使用被代理類的在Subject接口中聲明過的方法)
   
        所謂Dynamic Proxy是這樣一種class:它是在運(yùn)行時(shí)生成的class,在生成它時(shí)你必須     提供一組interface給它,然后該class就宣稱它實(shí)現(xiàn)了這些 interface。你當(dāng)然可以把    該class的實(shí)例當(dāng)作這些interface中的任何一個(gè)來用。當(dāng)然,這個(gè)Dynamic Proxy其實(shí)   就是一個(gè)   Proxy,它不會(huì)替你作實(shí)質(zhì)性的工作,在生成它的實(shí)例時(shí)你必須提供一個(gè)handler,由它    接管實(shí)際的工作。

在使用動(dòng)態(tài)代理類時(shí),我們必須實(shí)現(xiàn)InvocationHandler接口:
    參見程序 Subject.java
    參見程序 RealSubject.java
    參見程序 DynamicSubject.java
    參見程序 Client.java

 

復(fù)制代碼代碼如下:

package com.langsin.dynamicproxy;
//抽象角色(之前是抽象類,此處應(yīng)改為接口): 
public interface Subject
{
    abstract public void request();
}

 

 

復(fù)制代碼代碼如下:

package com.langsin.dynamicproxy;
//具體角色
public class RealSubject implements Subject
{
    public RealSubject()
    {
     
    }
    public void request()
    {
        System.out.println("From real subject.");
    }
}

 

 

復(fù)制代碼代碼如下:

package com.langsin.dynamicproxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
//代理處理器 
/**
 * 該代理類的內(nèi)部屬性為Object類,實(shí)際使用時(shí)通過該類的構(gòu)造函數(shù)DynamicSubject(Object obj)對其賦值;
 * 此外,在該類還實(shí)現(xiàn)了invoke方法,該方法中的 method.invoke(sub,args);
 * 其實(shí)就是調(diào)用被代理對象的將要被執(zhí)行的方法,方法參數(shù)sub是實(shí)際的被代理對象,
 * args為執(zhí)行被代理對象相應(yīng)操作所需的參數(shù)。
 * 通過動(dòng)態(tài)代理類,我們可以在調(diào)用之前或之后執(zhí)行一些相關(guān)操作
 */
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;
    }
}

 

 

復(fù)制代碼代碼如下:

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

 

實(shí)例2:

 

復(fù)制代碼代碼如下:

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

 

實(shí)例3、

 

復(fù)制代碼代碼如下:

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{
    // 動(dòng)態(tài)執(zhí)行對象,需要回調(diào)的對象
    private Object target;
    // 支持構(gòu)造子注射
    public CommonInvocationHandler(){
    }
    // 支持構(gòu)造子注射
    public CommonInvocationHandler(Object target){
        setTarget(target);
    }
    /**
     * 
     * 采用setter方法注射
     * 
     * @param target
     * 
     */
    public void setTarget(Object target){
        this.target = target;
    }
    /**
     * 
     * 調(diào)用proxy中指定的方法method,并傳入?yún)?shù)列表args
     * 
     * @param proxy
     *            代理類的類型,例如定義對應(yīng)method的代理接口
     * 
     * @param method
     *            被代理的方法
     * 
     * @param args
     *            調(diào)用被代理方法的參數(shù)
     * 
     * @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.通用的動(dòng)態(tài)代理實(shí)現(xiàn)
        CommonInvocationHandler handler = new CommonInvocationHandler();
        Foo f;
        // 2.接口實(shí)現(xiàn)1
        handler.setTarget(new FooImpl());
        // 方法參數(shù)說明:代理類、代理類實(shí)現(xiàn)的接口列表、代理類的處理器
        // 關(guān)聯(lián)代理類、代理類中接口方法、處理器,當(dāng)代理類中接口方法被調(diào)用時(shí),會(huì)自動(dòng)分發(fā)到處理器的invoke方法
        // 如果代理類沒有實(shí)現(xiàn)指定接口列表,會(huì)拋出非法參數(shù)異常
        f = (Foo) Proxy.newProxyInstance(Foo.class.getClassLoader(),
        new Class[] { Foo.class },
        handler);
        f.doAction();
        // 3.接口實(shí)現(xiàn)2
        handler.setTarget(new FooImpl2());
        f = (Foo) Proxy.newProxyInstance(Foo.class.getClassLoader(),
        new Class[] { Foo.class },
        handler);
        f.doAction();
    }
}

 

由于本人文采有限,所以大部分內(nèi)容都是代碼,還請大家諒解^_^

延伸 · 閱讀

精彩推薦
  • JAVA教程Java獲得一個(gè)數(shù)組的指定長度排列組合算法示例

    Java獲得一個(gè)數(shù)組的指定長度排列組合算法示例

    這篇文章主要介紹了Java獲得一個(gè)數(shù)組的指定長度排列組合算法,結(jié)合實(shí)例形式分析了java排列組合相關(guān)數(shù)組遍歷、運(yùn)算操作技巧,需要的朋友可以參考下...

    iteye_162031712019-06-25
  • JAVA教程Java多線程yield心得分享

    Java多線程yield心得分享

    前幾天復(fù)習(xí)了一下多線程,發(fā)現(xiàn)有許多網(wǎng)上講的都很抽象,所以,自己把網(wǎng)上的一些案例總結(jié)了一下 ...

    java教程網(wǎng)5012019-10-25
  • JAVA教程Java創(chuàng)建多線程的兩種方式對比

    Java創(chuàng)建多線程的兩種方式對比

    在Java中創(chuàng)建線程的方式有兩種,第一種是直接繼承Thead類,另一種是實(shí)現(xiàn)Runable接口。那么這兩種方式孰優(yōu)孰劣呢?這就是本文需要探討的內(nèi)容范疇了,看官...

    hebedich4532019-12-04
  • JAVA教程Java中常用的6種排序算法詳細(xì)分解

    Java中常用的6種排序算法詳細(xì)分解

    這篇文章主要介紹了Java中常用的6種排序算法詳細(xì)分解,著重說明每個(gè)算法的計(jì)算過程分解,是探究實(shí)現(xiàn)原理級(jí)的文章,對于深入理解這些算法有很大幫助,需要...

    junjie1182019-11-25
  • JAVA教程Java parseInt解釋加方法示例

    Java parseInt解釋加方法示例

    使用此方法得到的原始數(shù)據(jù)類型的一個(gè)特定的字符串。 parseXxx()是一個(gè)靜態(tài)方法,可以有一個(gè)參數(shù)或兩個(gè) ...

    java教程網(wǎng)4672019-10-18
  • JAVA教程java程序中foreach用法示例

    java程序中foreach用法示例

    這篇文章主要介紹了java程序中foreach用法示例,需要的朋友可以參考下 ...

    Java教程網(wǎng)3842019-11-20
  • JAVA教程運(yùn)行java的class文件方法詳解

    運(yùn)行java的class文件方法詳解

    這篇文章主要詳細(xì)介紹了運(yùn)行java的class文件方法的相關(guān)資料,需要的朋友可以參考下 ...

    hebedich4662019-12-10
  • JAVA教程Windows搭建部署RocketMQ步驟詳解

    Windows搭建部署RocketMQ步驟詳解

    這篇文章主要介紹了Windows搭建部署RocketMQ步驟詳解,RocketMq是一個(gè)由阿里巴巴開源的消息中間件,脫胎去阿里每部使用的MetaQ,在設(shè)計(jì)上借鑒了Kafka。,需要的朋...

    老郭8542019-06-26
主站蜘蛛池模板: 国产精品福利在线观看 | 女教师高潮叫床视频在线观看 | 久久久久亚洲精品 | 精品在线一区二区三区 | 亚洲一区二区三区在线 | 日韩超级大片免费看国产国产播放器 | 国产欧美精品一区二区三区 | 久久99精品久久久久久国产越南 | 日韩成人在线一区二区 | 午夜精品福利一区二区三区蜜桃 | 成人a视频 | 亚洲 欧美 日韩 在线 | 日韩高清在线 | 色综合天天天天做夜夜夜夜做 | 电影一级毛片 | 黄色国产一级片 | 国产精品综合一区二区 | 日韩福利视频 | 国产精品毛片 | 久久这里只有国产精品 | 国产精品高潮呻吟久久av野狼 | 四季久久免费一区二区三区四区 | 国产精品久久久久久 | 亚洲欧美另类在线 | 爱爱网av| 久久成| 国产视频第一页 | 亚洲精品国产精品国自产在线 | 午夜av网站| 视频一区二区国产 | 成人黄大片视频在线观看 | 亚洲高清av| 成人三级视频 | 免费h| 高清av电影 | 美女久久| 精品一区二区在线观看 | 久久美女 | 亚洲一区| 久久精品国产一区二区三区不卡 | 91久久国产精品 |