IDEA报错:java.lang.NoSuchFieldError 和 NoSuchMethodError

文章介绍了在Java开发中遇到NoSuchFieldError和NoSuchMethodError的场景,分析了两种可能的原因:jar包版本冲突和项目中存在同名类。提供了通过Maven的依赖管理工具排查和解决问题的步骤,包括检查依赖冲突、排除不需要的jar包以及检查项目中是否存在相同路径和命名的类。最后提醒,如果排除冲突后问题仍存在,可能是pom.xml重复引入了jar包,需要删除重复项。

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>
1
2
3
4
5
6
7
8
9
10
11
顺手推荐一个工具:Maven Helper
2、第二步:排查你们项目中有相同路径和命名的类


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

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

原文链接:https://blog.youkuaiyun.com/weixin_39452168/article/details/108146847

---------------------------------------------------------------------------------------------------------------------

注:安装上述方法排查问题时,发现确实是两个相同的jar包冲突了,但是通过<exclusions>屏蔽掉其中一个jar包后还是报同样的问题,经过检查后发现是pom.xml文件引入了两次相同jar包,所以在注释掉一个之后还是不行。

解决方式:删除相同的jar包,然后通过<exclusions>屏蔽。

 

 

 


 

### Java `NoSuchFieldError` 错误的原因 当 JVM 尝试访问类中的字段而该字段不存在时,会抛出 `java.lang.NoSuchFieldError`。此异常通常发生在运行时版本与编译时使用的库不兼容的情况下[^1]。 具体来说,此类错误可能由以下几个因素引起: - **不同版本冲突**:项目依赖的不同模块之间存在版本差异,导致某些字段在特定版本中被移除或重命名。 - **字节码操作不当**:如果应用程序直接修改了类文件结构(例如通过反射机制),可能会破坏原有的成员变量定义。 - **第三方框架集成问题**:像 MyBatis Plus 这样的持久层框架,在使用自定义注解如 @Select 时可能出现初始化失败的情况,这可能是由于内部静态常量未正确定义所致[^4]。 ### 解决方案概述 针对上述提到的各种情况,可以采取如下措施来解决问题: #### 版本一致性检查 确保所有相关组件及其依赖项都处于相同的主要版本系列内,并且尽可能保持一致的小版本号。对于 Spring Boot MyBatis Plus 的组合而言,建议查阅官方文档获取推荐搭配列表[^2]。 #### 更新依赖关系管理工具配置 利用 Maven 或 Gradle 等构建工具锁定项目的外部库到指定版本,防止意外引入其他分支上的变更。同时注意清理本地仓库缓存以防残留旧版二进制包影响打包过程[^3]。 #### 验证源代码与目标平台匹配度 确认所编写的应用程序逻辑不会违反任何底层 API 合约;特别是涉及私有实现细节的部分更需谨慎处理。此外还需留意 JDK 安装环境是否干净无污染以及插件扩展功能是否正常工作。 ```xml <!-- Example of dependency management in pom.xml --> <dependencyManagement> <dependencies> <!-- Specify exact versions here --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> ... </dependencies> </dependencyManagement> ``` #### 调整应用启动参数 有时可以通过调整 JVM 参数绕过潜在的问题区域。比如设置 `-noverify` 来跳过部分验证步骤,但这应该作为最后手段考虑因为这样做会影响安全性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值