- 今天遇到了一个问题(如题),我在思考要不要记录下,最终决定写一个简单的小记录。我感觉大牛必备的两个技能: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一下,不会有其他可能。