当前位置:首页 > java基础 > 正文内容

动态代理

淙嶙5年前 (2020-07-20)java基础1251

一、实现动态代理的方式:

  • jdk动态代理
  • CGlib动态代理
  • javassist动态代理

CGlib底层实现依赖于ASM, javassist自成一派. 由于ASM和javassist需要程序员直接操作字节码,导致使用技术门槛较高,JDK底层使用反射,但是最终也是操作字节码. Dubbo采用的javassist代理,动态的在内存当中生成所代理的字节码,来完成代理的功能.

二、JDK动态代理

需要的必要条件: 该类需要实现一个接口,这个接口就是JDK动态代理的基础.

public interface Person{
    void speak();
    @MethodName("run")
    void run();
}

创建需要代理的类:

public class Wang implements Person {
    @Override
    public void speak() {
        System.out.println("You are so nice!");
    }

    @Override
    public void run() {
        System.out.println("Running is good for you!");
    }
}

创建代理类: 1) 代理类实现InvocationHandler接口 2) Proxy.newInstance() 方法创建代理类 3) 实现invoke方法

public class TargetProxyA implements InvocationHandler{
    private Object target;

    public TargetProxyA(Object target) {
        this.target = target;
    }

    public static Object getInstance(Object target) {
        return Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(),
                new TargetProxyA(target));
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        before();
        return method.invoke(target, args);
        after();
    }

    private void before(){
         System.out.println("操作前处理!");
    }

    private void after(){
         System.out.println("后续处理");
    }
}

调用代理

public class Client{
    public static void main(String[] args) {
        Person personWang = (Person) TargetProxyA.getInstance(new Wang());
        personWang.speak();
   }
}

相关文章

指令重排

指令重排

Happen-Before先行发生规则如果光靠sychronized和volatile来保证程序执行过程中的原子性, 有序性, 可见性, 那么代码将会变得异常繁琐. JMM提供了Happen-Bef...

ArrayList简介

ArrayList简介

ArrayList 是一个数组队列,相当于 动态数组。与Java中的数组相比,它的容量能动态增长。它继承于AbstractList,实现了List, RandomAccess, Cloneable,...

JVM总结

JVM总结

花费了一周时间对深入理解Java虚拟机做了个回顾,对原来的知识做了个补充,直到慢慢的阅读中,才发现有好多东西已经忘了。把所阅读的通过一个思维导图做个了简单的总结,时间仓促,还有不全。待十一节后继续补充...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。