NoClassDefFoundError在运行时但类在classes.dex中,有什么用途?

ste*_*bot 8 java eclipse android android-studio

我已经包含了一个从Eclipse Android项目构建的JAR文件,我在Android Studio项目中引用它,如下所示:

  compile files('libs/libraryproject.jar')
Run Code Online (Sandbox Code Playgroud)

这是有效的,我可以在代码引用上自动完成.当我编译APK时,一切都很好.我安装并运行,然后收到一个没有类def错误:

 java.lang.NoClassDefFoundError: com.android.canvas.CanvasContainer
            at com.app.MainActivity.onCreate(MainActivity.java:22)
            at android.app.Activity.performCreate(Activity.java:5231)
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
            at android.app.ActivityThread.access$800(ActivityThread.java:135)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5017)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)

但是,当我解压缩APK,并使用dexdump查看classes.dex文件时,我看到上面的类存在于那里.

为什么我在运行时遇到这个类没有找到错误?

更新:

感谢Chris的建议,我注意到在日志的早期,由于无法解析,我的CanvasContainer类无法链接 interface 1990 'Lorg/cocos2dx/lib/Cocos2dxHelper$Cocos2dxHelperListener;'.很明显,我的Cocos库代码似乎没有作为我的JAR的一部分导出.

Chr*_*ton 3

具有运行时无法满足的依赖关系的类通常会在安装、dex 优化或类似的准备过程中被删除。

如果您卸载该应用程序,启动一些收集所有 logcat 的程序,然后再次安装它,您可能会通过搜索结果发现在安装/准备过程中生成的日志中隐藏了该问题。

在此特定情况下,对问题的编辑表明缺少的类本身具有这种类型的未满足的依赖关系。