问题描述

工程中明明有该方法,却提示 java.lang.NoSuchMethodError 错误

1.原因

java 的类加载机制是把所有不同名称的本类和引用类的包全部加载到内存,这样就有一个问题,如果有两个类在JVM看来是完全一样的(包名和类名完全一样,即全限定名一样)怎么办,机器无法区分

举个栗子,
引用类,即引用别人包中的类(其包名:com.qq.dto):

public class Data(){
    public static getData(){
       System.out.println("引用类");
    }
}

本类,即自己写的类(其包名也是:com.qq.dto):

public class Data(){
    public static getData(){
       System.out.println("本类");
    }
    public static getDataOut(){
       System.out.println("本类");
    }
}

上述两个类在JVM看来是完全一样的(全限定名一样),JVM 只会加载一个类。如果先加载引用类,在调用 Data.getData 方法时,机器肯定先去使用引用类的 getData 方法,可实际需要调用本类的方法,这样肯定就会出错,如果调用想调用本类的 Data.getDataOut方法,因为内存加载的是引用类,就会发生找不到方法的错误。

2.解决

最简单的解决就是全限定名不一样(改包名或类名),这样就可以完全区分开来。
可以用 mvn dependency:analyze,mvn dependency:tree 命令辅助分析加载包的顺序。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐