大家好,我是你的好朋友思创斯。今天说一说javanosuchmethoderror_error java compilation failed,希望您对编程的造诣更进一步.
背景
abstractmethoderror异常对于我来说还是比较不常遇见的,最近有幸遇到,并侥幸的解决了,在这里把此种场景剖析一番,进入正题,下面是abstractmethoderror在java的异常机制中所处的位置:
现在明确了abstractmethoderror所具有的特性:
1.它是error的子类,error类及其子类都是被划分在非检查异常之列的,就是说这些异常不能在编译阶段被检查出来,只能在运行时才会触发。
2.通过api文档里面的解释大致得出的结论就是说a依赖于b,但是执行的时候发现类b的定义发生了改变,这个改变是针对编译的时候发生了改变,也就是说将类a由java文件编译成.class文件的时候用到了类b的class文件,但是在执行的时候jvm发现真正用到的b的class文件和编译的时候用的不是一个了。于是这个异常就被抛了出来。
至此,abstractmethoderror发生的底层原因也了解的差不多了,再往深层的话就是java的编译机制,以及java代码的执行检查这些更靠近虚拟机的东东,那些我也没什么研究,暂且不表。
底层原因了解了,我们继续谈下平常遇到的更直观的场景:
classa ->classb classa 依赖于classb,通常a是我们自己开发的类,而b则是引用的第三方jar包里面的类。我们的项目中又存在classb的多个版本,比如:1.0,1.2,2.0等版本,通常主版本号发生了改变的话,一般都是不兼容的。
类a
class a {
b dependency = new bimpl();
public void testmethod(){
dependency.changedmethodindifversion(arg1, arg2);
}
}
是否还在为ide开发工具频繁失效而烦恼,来吧关注以下公众号获取最新激活方式。亲测可用!
【正版授权,激活自己账号】:
【官方授权 正版激活】:
1.0版本的类b:
abstract class b {
public abstract void changedmethodindifversion(int arg1);
}
2.0版本的classb:
abstract class b {
public abstract void changedmethodindifversion(int arg1, string arg2);
}
如果在编译的时候使用的2.0版本中的这个classb,然而执行的时候使用的又是1.0版本的classb,那么就会抛出abstractmethoderror,这个异常抛出以后会把运行时真正找到的那个方法签名给打印出来的,异常信息会入下:
exception in thread xxxxx java.lang.abstractmehoderror package.class.运行时实际找到的方法
这个时候在你的classpath中寻找这个类,剔除掉不需要的版本就可以了。
文章由思创斯整理,转载请注明出处:https://ispacesoft.com/141429.html