zoukankan      html  css  js  c++  java
  • 一个简单JDK动态代理的实例

    动态代理的步骤:

    1. 创建一个实现了InvocationHandler接口的类,必须重写接口里的invoke()方法。
    2. 创建被代理的类和接口
    3. 通过Proxy的静态方法 newProxyInsatance(ClassLoader loader,Class[] interfaces,InvocationHandler,handler)来创建一个代理
    4. 通过代理来调用方法

    简单的动态代理实例

    package com.sean.zzzjvm;
    
    import java.lang.reflect.InvocationHandler;
    import java.lang.reflect.Method;
    import java.lang.reflect.Proxy;
    
    /**
     *
     * @Author Sean
     * @Date 2017/8/20 21:43.
     * @Version
     */
    public class DynamicProxyTest {
    
        //定义一个接口
        interface IHello{ 
            void sayHello();
        }
    
        //实现该接口的类
        static class Hello implements IHello{ 
    
            @Override
            public void sayHello() {
                System.out.println("hello world");
            }
        }
    
        //创建一个动态代理类,实现InvocationHandler接口
        static class DynamicProxy implements InvocationHandler{ 
            Object originalObj;
            
            //创建一个代理的方法,在new DynamicProxy().bind(new Hello());执行
            Object bind (Object originalObj){
                this.originalObj = originalObj;
                //返回一个代理对象
                return Proxy.newProxyInstance(originalObj.getClass().getClassLoader(),
                        originalObj.getClass().getInterfaces(),this);
            }
    
            //默认重写的方法,在 hello.sayHello()执行
            @Override
            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                System.out.println("welcome");
                return method.invoke(originalObj,args);
            }
        }
    
        public static void main(String[] args){
            // IHello hello = new Hello();
            //调用动态代理的方法
             IHello hello = (IHello) new DynamicProxy().bind(new Hello());
            hello.sayHello();
        }
    
    }
  • 相关阅读:
    lufylegend:图形变形3
    javascript: Math.sin() cos() 用法
    lufylegend:图形变形2
    lufylegend:图形变形1
    lufylegend:图片的加载和显示
    lufylegend基础知识1
    canvas使用3
    canvas使用2
    canvas使用1
    javascript:addEventListener
  • 原文地址:https://www.cnblogs.com/waliwaliwa/p/7441630.html
Copyright © 2011-2022 走看看