当前位置: 代码迷 >> 综合 >> 一步步排查解决java.lang.NoSuchFieldError 和 NoSuchMethodError问题
  详细解决方案

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

热度:93   发布时间:2024-02-13 07:00:02.0
  • 今天遇到了一个问题(如题),我在思考要不要记录下,最终决定写一个简单的小记录。我感觉大牛必备的两个技能: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一下,不会有其他可能。

  相关解决方案