【问题标题】:App crashes at runtime due to library project resources missing由于缺少库项目资源,应用程序在运行时崩溃
【发布时间】:2014-11-05 18:46:52
【问题描述】:

我一直在开发一个可以在这里看到的库:https://github.com/afollestad/material-dialogs

由于新的 Android Studio(0.8.14 Beta)、Gradle 和 SDK 构建工具更新,我最近创建了一个新项目并复制了 Java/XML/Drawables。当我尝试运行我创建的示例项目时突然遇到了一个问题,它昨天运行良好。

这是当用户单击示例中的按钮之一时在运行时引发的异常:

java.lang.NoClassDefFoundError: Failed resolution of: Lcom/afollestad/materialdialogs/R$color;
            at com.afollestad.materialdialogs.MaterialDialog$Builder.<init>(MaterialDialog.java:389)
            at com.afollestad.materialdialogssample.MainActivity.showCallbacks(MainActivity.java:143)
            at com.afollestad.materialdialogssample.MainActivity.access$400(MainActivity.java:24)
            at com.afollestad.materialdialogssample.MainActivity$5.onClick(MainActivity.java:62)
            at android.view.View.performClick(View.java:4756)
            at android.view.View$PerformClick.run(View.java:19749)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.afollestad.materialdialogs.R$color" on path: DexPathList[[zip file "/data/app/com.afollestad.materialdialogssample-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
            at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
            at com.afollestad.materialdialogs.MaterialDialog$Builder.<init>(MaterialDialog.java:389)
            at com.afollestad.materialdialogssample.MainActivity.showCallbacks(MainActivity.java:143)
            at com.afollestad.materialdialogssample.MainActivity.access$400(MainActivity.java:24)
            at com.afollestad.materialdialogssample.MainActivity$5.onClick(MainActivity.java:62)
            at android.view.View.performClick(View.java:4756)
            at android.view.View$PerformClick.run(View.java:19749)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5221)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
    Suppressed: java.lang.ClassNotFoundException: com.afollestad.materialdialogs.R$color
            at java.lang.Class.classForName(Native Method)
            at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
            at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
            ... 15 more
     Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available

当类MaterialDialog 被实例化时,它会检索颜色和尺寸等资源。无论出于何种原因,这些似乎都没有被转移到 APK 文件中。我认为这可能是一个明显的合并问题。

【问题讨论】:

  • 你用的是什么IDE?
  • @VenomVendor 它在开头列出:) Android Studio 0.8.14 Beta
  • 你能尝试一下 clean & build 一次吗!
  • @VenomVendor 我已经尝试了几次,不幸的是在运行时没有成功。
  • 我导入了你的 repo 并尝试了各种 gradle 配置,但抛出了同样的错误。

标签: java android exception classnotfoundexception library-project


【解决方案1】:

通过创建另一个项目解决了这个问题。不知道第二次有什么不同o.O

【讨论】:

  • 在删除构建文件后尝试使用 Beyond compare 比较两个项目,如果可能的话,让我知道导致问题的差异。
猜你喜欢
  • 2016-05-25
  • 2018-09-14
  • 1970-01-01
  • 2019-05-16
  • 1970-01-01
  • 2018-06-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多