Android Studio 2.3 无法使用即时运行 : debug apk crash with ClassNotFoundException

标签 android android-studio firebase

在 Android Studio 2.3 更新(和 gradle 更新)之后,如果我激活了即时运行,并且我通过运行从 Android Studio 安装应用程序或生成签名的 apk,它工作正常。

如果我手动安装调试 apk,它会在打开时立即崩溃,并显示 ClassNotFoundException

注意:如果我删除对文件提供程序的引用,未找到的类将成为主要 Activity 。此问题与在 Build-->Output-->apk 文件夹中生成的调试 apk 有关。如果您直接运行应用程序,它总是运行良好。

没有即时运行就没有崩溃。使用以前版本的 Android Studio 也没有崩溃。

java.lang.RuntimeException: Unable to get provider com.google.firebase.provider.FirebaseInitProvider: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.vfirst.ifbagro-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.vfirst.ifbagro-1, /vendor/lib, /system/lib]]
at android.app.ActivityThread.installProvider(ActivityThread.java:4993)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4596)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4536)
at android.app.ActivityThread.access$1300(ActivityThread.java:149)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1353)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5214)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:739)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.vfirst.ifbagro-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.vfirst.ifbagro-1, /vendor/lib, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)
at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
at android.app.ActivityThread.installProvider(ActivityThread.java:4978)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4596) 
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4536) 
at android.app.ActivityThread.access$1300(ActivityThread.java:149) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1353) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:137) 
at android.app.ActivityThread.main(ActivityThread.java:5214) 
at java.lang.reflect.Method.invokeNative(Native Method) 

最佳答案

我有同样的错误,我用 MultiDex 解决了它 添加 build.gradle multiDexEnabled "true"。

  android {
        defaultConfig {
            ...
            minSdkVersion 15 
            targetSdkVersion 25
            multiDexEnabled true
        }
        ...
    }

    dependencies {
      compile 'com.android.support:multidex:1.0.1'

此链接中的描述:https://developer.android.com/studio/build/multidex.html

关于Android Studio 2.3 无法使用即时运行 : debug apk crash with ClassNotFoundException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42885270/

相关文章:

android - 打开失败 : EACCES (Permission denied)

android - 删除 avd 文件

Android IllegalStateException 未注册仪器!必须在注册仪器下运行

java - Java 中 Intent 之间的困难 (Android Studio)

javascript - 或 Firebase 中的查询

firebase - 应用程序检查 Firebase 可调用函数上不必要的强制执行

java - 获取动态链接,而不是深层链接 - Android 上的 Firebase 动态链接

android - 清理 Genymotion 虚拟设备本地缓存

android - "Content has view with id attribute ' android.r.id.list ' that is not a ListView Class."在 fragment 中创建 ListView 时

java.lang.NoClassDefFoundError 与 tomcat 和 axis2