Android Studio 2.3无法使用即时运行:使用ClassNotFoundException调试apk崩溃

时间:2017-03-19 10:04:23

标签: android android-studio firebase

Android Studio 2.3更新(和gradle更新)后,如果我已启动即时运行,并且我通过运行或生成已签名的apk从Android Studio安装应用程序,则可以正常运行。

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

注意:如果删除对文件提供程序的引用,则找不到的类将成为主要活动。此问题是在构建 - >输出 - > 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) 

3 个答案:

答案 0 :(得分:0)

我遇到了同样的错误,我用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

答案 1 :(得分:0)

试试这个:

  android {
        defaultConfig {
            minSdkVersion 14 
            targetSdkVersion 25
            multiDexEnabled true
        }
    }

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

此代码进入您的清单:

   <application
       ...
       android:name="android.support.multidex.MultiDexApplication">
       ...
   </application>

如果您使用自定义应用程序类,请使用以下代码:

public class YouApplication extends Application {

    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        MultiDex.install(this);
    }

}

然后是清单:

   <application
       ...
       android:name="YOUR_PACKAGE.YouApplication">
       ...
   </application>

我希望能帮助你的朋友

答案 2 :(得分:-2)

对于我,我尝试了以下操作:尝试检查手机的自动启动管理器是否允许您的应用自动启动。通过允许您的应用程序自动启动,我认为将有助于修复即时运行问题。希望这有帮助。