一步步排查解决java.lang.NoSuchFieldError 和 NoSuchMethodError问题

  • 今天遇到了一个问题(如题),我在思考要不要记录下,最终决定写一个简单的小记录。我感觉大牛必备的两个技能:1、设计别人想不到的架构 2、解决别人无可奈何的问题。
  • 遇到下面这个问题会有四种人。(第四种人看完整篇文章)
  • 1、如果你之前没有遇到过,你会越查越崩溃;
  • 2、如果你之前遇到过,解决了,可能在比较明显的情况下会能快速定位,但是在很多情况下,查了好久之后你会怀疑自己说的到底对不对。
  • 3、第三种人遇到过这个问题,查了半天查不到,然后就一顿胡乱操作最后莫名其妙的好了、或者别人给解决、在差劲一点的就换个恶心的代码写法就完事啦,恭喜你永远的程序员。

1、报错信息

  • java.lang.NoSuchFieldError 和 NoSuchMethodError

2、场景

  • 通过Maven引入了一个jar包,某一天新增了一个类的属性或者静态属性。然后发现编译完全正确,但是实际运行一直在报NoSuchFieldError。

3、造成原因只有以下两种(不用想其他的,没有其他可能)

1、你项目中有同一个jar包的不同版本,编译和运行时使用了不同的jar包。比如有两个版本1.1.3和1.1.4(有新增属性)。编译的时候使用1.1.4,编译正常通过。但是运行的时候使用的是1.1.3。
2、你的项目中存在和jar包中路径和类名完全相同的类。因为你新增了属性本地类中没有,所以编译的时候会自动使用Jar包中的对象,但是运行的时候则会优先使用本地的对象!!!

4、排查流程

1、第一步:排查存在多个Jar包引用
  • 使用ideal自带到Maven工具(show Dependencies),如果查处两个的话就要注意啦(敲黑板),你可以直接点到不是你需要的那个版本,进入查看下是从哪个地方依赖的。在这里插入图片描述
  • 如果是你项目引入的,直接删掉就解决啦,如果是传递依赖(你引用的jar引用了这个jar包),需要使用标签去排除掉。
 <dependency>
        <groupId>io.vertx</groupId>
        <artifactId>vertx-core</artifactId>
        <version>${vertx.version}</version>
        <exclusions>
            <exclusion>
                <artifactId>netty-codec</artifactId>
                <groupId>io.netty</groupId>
            </exclusion>
        </exclusions>
</dependency>
  • 顺手推荐一个工具:Maven Helper
2、第二步:排查你们项目中有相同路径和命名的类

在这里插入图片描述

敲黑板:一定要勾选上include non-project items 才能查询到jar包中的类。如果本地有一样的话,看你的抉择啦,删除哪一个你自己选。

上面两步绝对解决问题,如果你试过还是没找到原因,那你找下你的同事check一下,不会有其他可能。

  • 18
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值