动态代理的使用

本文介绍了Java动态代理的概念,展示了如何使用Proxy类创建动态代理并实现多个接口。动态代理在调用方法时,会触发InvocationHandler的invoke方法,允许在方法调用前后插入自定义逻辑。示例代码中,动态代理对象代理了IMassage和IWash接口,并通过强转调用了massage方法。此外,还展示了如何在invoke方法中通过反射调用实际实体类的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 动态代理的概念:相对于静态代理,动态代理可以一次性代理多个服务,而且JDK实现的动态代理只能代理接口。

    动态代理用到的类: Proxy

    Proxy的使用方法:

     public class ProxyClass {
    
         public static void main(String[] args) {
     
             Tom tom  = new Tom();
     
             //创建动态代理
             final Object proxyInstance = Proxy.newProxyInstance(ProxyClass.class.getClassLoader(),
                     new Class[]{IMassage.class, IWash.class}, new InvocationHandler() {
                         @Override
                         public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                             System.out.println("Hello 动态代理");
     
                             return null;
                         }
                     });
     
             IMassage iMassage = (IMassage) proxyInstance;
             iMassage.massage();
     
         }
     }
    
  2. 动态代理的使用讲解:
    proxyInstance对象代理了IMassage和IWash两个抽象的接口,所以可以通过proxyInstance对象获取IMassage和IWash对象。

    //通过强转的方式就可以获取IMassage对象,然后调用massage方法。
    IMassage iMassage = (IMassage) proxyInstance;
    iMassage.massage();
    
  3. InvocationHandler的作用

     public interface InvocationHandler {
    
         public Object invoke(Object proxy, Method method, Object[] args)
             throws Throwable;
      }
    

    通过以上代码可以看出其实InvocationHandler是一个接口,作用就是当我们通过代理对象调用代理方法时,InvocationHandler就会监听到此方法,然后把调用的方法传进invoke方法。所以代码部分的打印语句就会输出结果了。

  4. 运行结果:

    在这里插入图片描述

  5. 代理真正的实体类
    通过反射的方式获取代理类对象,然后执行代理类的方法。以下是代码部分:

    public class ProxyClass {
    
        public static void main(String[] args) {
    
    
            final Tom tom  = new Tom();
    
            //创建动态代理
            final Object proxyInstance = Proxy.newProxyInstance(ProxyClass.class.getClassLoader(),
                    new Class[]{IMassage.class, IWash.class}, new InvocationHandler() {
                        @Override
                        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
    
    						// 只需要在return的时候通过invoke方法,把实体类对象传进来就可以了
                            return method.invoke(tom, args);
                        }
                    });
    
            IMassage iMassage = (IMassage) proxyInstance;
            iMassage.massage();
    
        }
    }
    
  6. 运行结果:
    在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不搞复杂看不懂的文章

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值