【问题标题】:java.lang.NoClassDefFoundError when running app with Android 5.1 with Android Studio 2.2RCjava.lang.NoClassDefFoundError 使用 Android Studio 2.2RC 运行带有 Android 5.1 的应用程序时
【发布时间】:2017-01-14 05:27:09
【问题描述】:

在使用搭载 Android 6.0 或 Android 7.0 的设备时,我的应用程序构建和运行正常,但在运行搭载 Android 5.1 的任何设备时(尚未测试过更低版本),它会失败,并出现以下异常:

09-06 11:50:46.100 29601-29601/? E/AndroidRuntime: FATAL EXCEPTION: main
                                               Process: me.myapp.main, PID: 29601
                                               java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/common/internal/zzab;
                                                   at com.google.firebase.provider.FirebaseInitProvider.zza(Unknown Source)
                                                   at com.google.firebase.provider.FirebaseInitProvider.attachInfo(Unknown Source)
                                                   at android.app.ActivityThread.installProvider(ActivityThread.java:5084)
                                                   at android.app.ActivityThread.installContentProviders(ActivityThread.java:4679)
                                                   at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4619)
                                                   at android.app.ActivityThread.access$1500(ActivityThread.java:155)
                                                   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1378)
                                                   at android.os.Handler.dispatchMessage(Handler.java:102)
                                                   at android.os.Looper.loop(Looper.java:135)
                                                   at android.app.ActivityThread.main(ActivityThread.java:5343)
                                                   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:905)
                                                   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)
                                                Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.common.internal.zzab" on path: DexPathList[[zip file "/data/app/me.myapp.main-1/base.apk"],nativeLibraryDirectories=[/data/app/me.myapp.main-1/lib/arm, /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.google.firebase.provider.FirebaseInitProvider.zza(Unknown Source) 
                                                   at com.google.firebase.provider.FirebaseInitProvider.attachInfo(Unknown Source) 
                                                   at android.app.ActivityThread.installProvider(ActivityThread.java:5084) 
                                                   at android.app.ActivityThread.installContentProviders(ActivityThread.java:4679) 
                                                   at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4619) 
                                                   at android.app.ActivityThread.access$1500(ActivityThread.java:155) 
                                                   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1378) 
                                                   at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                   at android.os.Looper.loop(Looper.java:135) 
                                                   at android.app.ActivityThread.main(ActivityThread.java:5343) 
                                                   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:905) 
                                                   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700) 
                                                Suppressed: java.lang.ClassNotFoundException: com.google.android.gms.common.internal.zzab
                                                   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

我已经确保我在我的 gradle 文件中包含了所有必要的库(在这种情况下,日志显示了一个 google 库,但它发生在其他库中)。我还确保 Multidex 已启用并尝试清理和重建项目以及删除应用程序并重新安装。

我已经隔离了一些可能导致崩溃的情况:

  • Instant Run 已禁用
  • 为多个设备构建应用程序

我使用的是 Android Studio 2.2RC

编辑:稳定版 2.2 仍在发生

【问题讨论】:

  • 确保您的所有 Google Play 服务都使用相同的版本号
  • 在 5.0.0 上对我来说相同,但在 6.0.0 上确实有效。除了 'com.android.tools.build:gradle:2.2.0' 之外,没有更改任何 gradle 文件(Google Play 服务都是相同的版本)。
  • 面临同样的问题,它在 5.0.0 上与 proguard 一起工作,但没有崩溃。
  • 并不真正相关,因为我的项目和应用程序已经为 Multidex @S.A.NortonStanley 配置了

标签: android noclassdeffounderror


【解决方案1】:

这里我们可以在 runtime/dex_file.cc 中看到什么

bool DexFile::OpenFromZip(...) {
    ...
    while (i < 100) {
        std::string name = StringPrintf("classes%zu.dex", i)
        ...
    }
    ...
}

所以如果你有超过 100 个 dex 文件,你会得到这个 NoClassDefFoundError。

此行为的跟踪器存在问题:

https://code.google.com/p/android/issues/detail?id=234367 https://code.google.com/p/android/issues/detail?id=170485

可以通过禁用 pre-dexing 来避免此错误。所以你可以把像

subprojects {
    project.plugins.whenPluginAdded { plugin ->
        if ("com.android.build.gradle.AppPlugin".equals(plugin.class.name)) {
            project.android.dexOptions.preDexLibraries = false
        } else if ("com.android.build.gradle.LibraryPlugin".equals(plugin.class.name)) {
            project.android.dexOptions.preDexLibraries = false
        }
    }
}

在根 build.gradle 文件中。

【讨论】:

  • 感谢您的参考和解决方案。我不敢相信这仍然是一个持续的错误!
【解决方案2】:

Android 5.1 有一个arbitrary limit of 100 dex files

一种可能的解决方法是禁用 preDexLibraries,这会减少 apk 中包含的 classes.dex 文件的数量。

添加

android {
    dexOptions {
        preDexLibraries false
    }
}

到应用程序的build.gradle 文件

【讨论】:

  • 这是基于 macros013 的答案,但我发现他从根 build.gradle 覆盖 dexOptions 的解决方案不必要地不透明。其他开发者不会在 root.gradle 中寻找 dex 选项!
【解决方案3】:

确保您使用的是 google.android.gms 的更新版本

使缓存无效,然后 在您的应用中进行更改:gradle 文件:

implementation 'com.android.support.constraint:constraint-layout:1.1.2'
//noinspection GradleCompatible
//noinspection GradleCompatible
implementation 'com.android.support:appcompat-v7:23.4.0'
implementation 'com.android.support:design:23.4.0'
implementation 'com.google.android.gms:play-services-maps:15.0.1'
implementation 'com.parse.bolts:bolts-tasks:1.4.0'
implementation 'com.parse:parse-android:1.13.0'
implementation 'com.android.support:multidex:1.0.3'

这对我有用

【讨论】:

    猜你喜欢
    • 2018-11-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-01-22
    • 2018-07-15
    • 2017-01-01
    • 1970-01-01
    相关资源
    最近更新 更多