debug模式下一起由idea默认调Object.toString引起的Spring生成动态代理类invoke异常

背景

项目中模仿OpenFeign声明式接口,实现了动态代理类方式生成接口的实现, 但是在idea中debug时发现,总是会在每一行的代码中都会调用动态代理类中的invoke方法, 这个invoke因有远程rpc调用,所有在debug时感觉非常明显的卡顿,但在调用的代码里打断点,又断不住,很是奇怪。

问题分析过程

1. 先打日志,既然断点不能断住,但又执行了, 那在执行的代码中打动态代理类执行的方法及Class名称打出来, 这时发现竟然执行了Object.toString()方法

2. 那为什么会执行了Object.toString()呢, 这其实是因为在idea debug模式下, idea为了显示对象的属性或展示需要需要调用对象的toString方法, 但我没有实现自定义的toString方法,所以,默认调用了Object.toString

3. 既然并不是只有指定方法才会调进来,那就equals/hashCode/toString 这些方法都有可能会调到动态代理类中

解决方案

在动态代理类的invoke方法加增加以下代码来处理equals/hashCode/toString的默认调用

 /**
         *  以下equals/hashCode/toString 非常重要,不能删除,
         *  否则在debug时,会调到Object.toString方法从而执行调用远程扩展点
         *  在debug时,调到此方法,但无法断点住,应该是idea工具上为了显示对象调用的
         *  参考https://blog.csdn.net/lkforce/article/details/90479650
        */
        if ("equals".equals(method.getName())) {
            try {
                Object otherHandler =
                        args.length > 0 && args[0] != null ? Proxy.getInvocationHandler(args[0]) : null;
                return equals(otherHandler);
            } catch (IllegalArgumentException e) {
                return false;
            }
        } else if ("hashCode".equals(method.getName())) {
            return hashCode();
        } else if ("toString".equals(method.getName())) {
            return toString();
        }

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值