您还可能在执行没有公共static void main()方法的类时抛出此错误。要了解其背后的原因,请阅读本文。
当您尝试调用某个类中不再可用的方法时,那么在编译时本身将显示一条错误消息“找不到符号”。 因此,您可能会认为启动程序或应用程序时会引发此错误。
我已经使用以下程序解释了此问题背后的事实。
让我们有一个如下的Nomethod和Pro1类,
方法类:
import java.util.*;class Nomethod{public static void main(String args[]){Pro1 s=new Pro1();s.display();}
}
Pro1类别:
class Pro1{public void display(){System.out.println("I am inside display");}
}
当您执行该程序时,它可以正常工作而不会显示任何错误。现在看看当我按如下方式更改Pro1类并单独编译该类时会发生什么。
范例1:
class Pro1
{
}
范例2:
class Pro1{public int void display(){System.out.println("I am inside display");return 1; // for example i have included a statement like this}
}
现在,如果您执行类Nomethod而不重新编译它,那么在运行时此java.lang.NoSuchMethodError将使您感到尴尬。
1.如果如示例1所示更改类Pro1,则将抛出此异常,因为该类中没有可用的方法display()。
2.如果考虑使用Example2,则会引发此错误,因为方法display()的签名已更改。
如果您理解了这些示例,那么您可能已经理解了执行没有main()方法的类时引发此错误的原因。 真正的事实是“与现有二进制文件(类)的二进制兼容性已被新的二进制文件(修改后的类)损害了”。
“当您更改方法的签名或删除特定类中的方法时,并单独对其进行编译,那么其他调用该方法的类将不知道该方法的状态,从而导致在运行时抛出此错误-时间。
同样的情况也适用于接口,“那时,如果您尝试更改方法的签名或删除接口中的方法”,也会抛出此异常。
有什么解决方案?
“如果您重新编译了另一个类,则该类将在该类或接口中调用此修改的方法或已删除的方法”,则此错误将在编译时显示,您可以执行必要的步骤来解决它。
注意:考虑到这种情况,即使您重新编译该类,情况也可能变得更糟,您将不会收到此错误的提示。
举例来说,您在项目中包含了较旧版本的软件包,并将其放置在扩展库中。您还拥有了较新的软件包(其中方法的签名已更改),并且您已经包含了该软件包在课程路径中。
编译类时,编译器将在扩展库和引导程序库中搜索类以解析引用,但Java虚拟机仅在已指定的类路径(对于第三方库)中搜索。
因此,在您的应用程序中使用新程序包时,请确保已修改了与旧版本相关的设置,并阅读了新程序包的文档以了解此程序包中所做的更改。
参考:来自Java错误和异常博客的JCG合作伙伴 Ganesh Bhuddhan提供的java.lang.NoSuchMethodError 。
翻译自: https://www.javacodegeeks.com/2012/08/java-exception-java-lang.html