运行时出现NoClassDefFoundError错误,但类在classes.dex中,是什么原因?

9
我已经包含了一个从Eclipse Android项目构建而成的JAR文件,并且我正在按照以下方式在我的Android Studio项目中引用它:
  compile files('libs/libraryproject.jar')

这个工作正常,我可以获得代码引用的自动补全。当我编译APK时一切都很好。我安装和运行后,出现了一个“无类定义”错误:

 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)

然而,当我解压APK并使用dexdump查看classes.dex文件时,我发现上述类在其中存在。
那么为什么我在运行时会收到"找不到该类"的错误?
更新:感谢Chris的建议,我注意到日志中早期CanvasContainer类无法链接,因为它无法解析“Lorg/cocos2dx/lib/Cocos2dxHelper $ Cocos2dxHelperListener”的1990个接口。很明显,我的Cocos库代码没有作为我的JAR的一部分导出。

CanvasContainer的基类是什么?它有可能是来自于比设备上API更新的某个类吗? - Selvin
6
如果运行时无法满足依赖关系的类通常会在安装过程中被删除。如果您卸载应用程序,然后启动某个收集整个logcat的东西,并重新安装它,您可能会通过在生成的安装日志中搜索发现有关该问题的提及。请注意,这些信息可能会被淹没在其他日志中。 - Chris Stratton
@ChrisStratton 很棒的观点,如果您愿意将其写成答案,我会接受它。我现在看到由于未解析接口1990 'Lorg/cocos2dx/lib/Cocos2dxHelper$Cocos2dxHelperListener;'而无法链接我的类。 - stevebot
@Selvin,不是的,但你走在了正确的轨道上。基类是一个Cocos2d库类,它没有与我的JAR文件一起被导出。异常并没有在编译时发生,而是在运行时由于缺少Cocos2d接口而发生。 - stevebot
有时候,最好的做法是晚上离开问题,听取其他人在SO上的意见,并在第二天回来解决它。如果不是Chris的建议,我可能要很久才能注意到早期的链接失败。 - stevebot
显示剩余2条评论
1个回答

3

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

如果您卸载应用程序,然后启动一些收集logcat的工具并重新安装它,您可能会通过搜索结果发现,在安装/准备过程中生成的日志中有关于问题的提及。

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

"Original Answer" 翻译成 "最初的回答"


1
奇迹啊,我多年未登录,却发现你仅在三天前发布了这篇文章。感谢你那时候的帮助! - stevebot

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接