NoClassDefFoundError原因
NoClassDefFoundError和ClassNotFoundException
在java开发的过程经常会遇到这两个异常并且时常会产生混淆,为了便于区别,特作如下总结:
- 相似点
- NoClassDefFoundError和ClassNotFoundException异常出现原因都是加载不到类导致,但是两者确有本质的区别。
- 不同点
- ClassNotfoundException是在编译过程中JVM加载不到类或者找不到类引起;
- NoClassDefError是在运行时JVM加载不到类或者找不到类引起;
NoClassDefFoundError错误发生原因
- NoClassDefFoundError错误发生原因与Java虚拟机的工作原理相关,下面简单介绍一下JVM的类加载机制,其中类加载器的三个机制为委托、单一性、可见性。
- 委托:指加载一个类的请求交给父类加载器,若父类加载器不可以找到或者加载到,再加载这个类;
- 单一性:指子类加载器不会再次加载父类加载器已经加载过的类 ;
- 可见性:子类加载器可以看见父类加载器加载的所有类,而父类加载器不可以看到子类加载器加载的类
JVM的委托机制决定了类加载器只加载一次,子类加载器不会再加载父类加载器已经加载过的类,因此在一些特定条件下就会出现编译时可以加载到类,运行时不可以加载到类,这时候就会出现java.lang.NoClassDefFoundError异常