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