前言:
NoClassDefFoundError和ClassNotFoundException相比,前者是类加载后直接抛出(一般属于VM抛出),后者一般是加载时抛出(一般属于ClassLoader抛出),很明显前者是在避免了ClassNotFoundException异常之后抛出的,直白一点就是,前者意味着类是存在的。
显然NoClassDefFoundError这种错误的根源,“链接“和”初始化“阶段发生,当然以初始化为主的比较多。
最终原因时:该类被虚拟机标记为无效的类。
原因:
为什么该类被提前标记为无效类呢?
(1)dexopt 类扫描 (Android 5.0之前版本特有的一类NoClassDefFoundError)
dexopt会扫描被该类A引用的所有的其他类是否存在,如果不存在,则其他类会被标记未无效类。
这种情况往往发生在使用multidex对main-dex分包后,由于没有找到类,会被标记为无效的类
(2)初始化时发生了异常
W/dalvikvm: Unable to resolve superclass of Lcom/tencent/bugly/beta/Beta; (68)
W/dalvikvm: Link of class 'Lcom/tencent/bugly/beta/Beta;' failed
W/dalvikvm: VFY: unable to resolve static field 154 (autoCheckUpgrade) in Lcom/tencent/bugly/beta/Beta;
D/dalvikvm: VFY: replacing opcode 0x6a at 0x0002
W/dalvikvm: Unable to resolve superclass of Lcom/tencent/bugly/crashreport/CrashReport$UserStrategy; (66)
W/dalvikvm: Link of class 'Lcom/tencent/bugly/crashreport/CrashReport$UserStrategy;' failed
D/dalvikvm: DexOpt: unable to opt direct call 0x0165 at 0x12 in Lcom/pitaya/buckettool/BucketApplication;.initBugly