RuntimeException:ClassNotFoundException android.arch.lifecycle.ProcessLifecycleOwnerInitializer
Posted
技术标签:
【中文标题】RuntimeException:ClassNotFoundException android.arch.lifecycle.ProcessLifecycleOwnerInitializer【英文标题】: 【发布时间】:2018-08-08 20:53:30 【问题描述】:我只在 android SDK
按照本指南进行设置 -> https://developer.android.com/topic/libraries/architecture/adding-components.html
App.java
public void onCreate()
super.onCreate();
ProcessLifecycleOwner.get().getLifecycle().addObserver(new AppLifecycleListener(this));
registerActivityLifecycleCallbacks(this);
AppLifecycleListener.java
public class AppLifecycleListener implements LifecycleObserver
private App app;
public AppLifecycleListener(App app)
this.app = app;
@OnLifecycleEvent(Lifecycle.Event.ON_START)
public void onMoveToForeground()
if (app.getCurrentActivity() instanceof BaseActivity)
BaseActivity baseActivity = (BaseActivity) app.getCurrentActivity();
baseActivity.runIsAPIVersionCheck();
baseActivity.fetchObjectsWithHUD(false);
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
public void onMoveToBackground()
分级
compileSdkVersion 26
dexOptions
javaMaxHeapSize "4g"
defaultConfig
applicationId "app"
minSdkVersion 16
targetSdkVersion 26
versionCode 71
versionName "4.9.9"
multiDexEnabled true
resConfigs "en"
javaCompileOptions
annotationProcessorOptions
includeCompileClasspath false
compile 'com.android.support:appcompat-v7:26.1.0'
compile 'com.android.support:support-v4:26.1.0'
compile 'com.android.support:design:26.1.0'
compile 'android.arch.lifecycle:extensions:1.1.0'
compile 'android.arch.lifecycle:compiler:1.1.0'
02-28 20:54:03.151 2558-2558/? E/AndroidRuntime: 致命异常: main java.lang.RuntimeException:无法获取提供者 android.arch.lifecycle.ProcessLifecycleOwnerInitializer:java.lang.ClassNotFoundException:android.arch.lifecycle.ProcessLifecycleOwnerInitializer 在 android.app.ActivityThread.installProvider(ActivityThread.java:4563) 在 android.app.ActivityThread.installContentProviders(ActivityThread.java:4190) 在 android.app.ActivityThread.handleBindApplication(ActivityThread.java:4132) 在 android.app.ActivityThread.access$1300(ActivityThread.java:130) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1255) 在 android.os.Handler.dispatchMessage(Handler.java:99) 在 android.os.Looper.loop(Looper.java:137) 在 android.app.ActivityThread.main(ActivityThread.java:4745) 在 java.lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:511) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 在 dalvik.system.NativeStart.main(本机方法) 引起:java.lang.ClassNotFoundException: android.arch.lifecycle.ProcessLifecycleOwnerInitializer 在 dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:501) 在 java.lang.ClassLoader.loadClass(ClassLoader.java:461) 在 android.app.ActivityThread.installProvider(ActivityThread.java:4548) 在 android.app.ActivityThread.installContentProviders(ActivityThread.java:4190) 在 android.app.ActivityThread.handleBindApplication(ActivityThread.java:4132) 在 android.app.ActivityThread.access$1300(ActivityThread.java:130) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1255) 在 android.os.Handler.dispatchMessage(Handler.java:99) 在 android.os.Looper.loop(Looper.java:137) 在 android.app.ActivityThread.main(ActivityThread.java:4745) 在 java.lang.reflect.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:511) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 在 dalvik.system.NativeStart.main(本机方法)
【问题讨论】:
你试过multiDexEnabled false
吗?
@ThomasMary 更改为 false 会产生此错误 -> 错误:任务 ':App:transformDexArchiveWithExternalLibsDexMergerForDebug' 执行失败。 > java.lang.RuntimeException: java.lang.RuntimeException: com.android.builder.dexing.DexArchiveMergerException: 无法合并 dex
implementation "android.arch.lifecycle:extensions:1.1.0" // alternatively, just ViewModel implementation "android.arch.lifecycle:viewmodel:1.1.0" // alternatively, just LiveData implementation "android.arch.lifecycle:livedata:1.1.0" annotationProcessor "android.arch.lifecycle:compiler:1.1.0"
确保你添加了所有这些
在同步 gradle 后刚刚添加了它们,同样的错误。 (developer.android.com/topic/libraries/architecture/…) // ViewModel 和 LiveData 实现 "android.arch.lifecycle:extensions:1.1.0" // 或者,只是 ViewModel 实现 "android.arch.lifecycle:viewmodel:1.1.0" // 或者,只是 LiveData实现 "android.arch.lifecycle:livedata:1.1.0" annotationProcessor "android.arch.lifecycle:compiler:1.1.0"
【参考方案1】:
这最终成为了一个多索引问题。我按照这里的文档-> https://developer.android.com/studio/build/multidex.html#mdex-gradle 现在效果很好!
分级:
implementation 'com.android.support:multidex:1.0.3'
App.java:
public class App extends Application implements Application.ActivityLifecycleCallbacks
@Override
protected void attachBaseContext(Context base)
super.attachBaseContext(base);
MultiDex.install(this);
【讨论】:
这非常超酷!还有multidex 1.0.3版 你知道为什么这只发生在较低的 API 上吗? @ArchieG.Quiñones 不能 100% 确定,只是假设 5.0 之前的错误已修复。 已修复?在较低的 Android 版本中运行我的应用时,我仍然遇到同样的问题。【参考方案2】:我所要做的就是将以下内容添加到我的 proguard-rules.pro
文件中:
-keep class android.arch.lifecycle.** *;
【讨论】:
这有帮助!知道为什么吗?我到处都有minifyEnabled = false
,我正在运行调试模式。我将我的应用程序迁移到使用androidx
,之后遇到了这个问题。【参考方案3】:
在我的例子中,不知何故,Android 架构生命周期文件在 Pie(Android9) 上的 Android 捆绑包中被省略了。所以我所做的是在proguard-rules.pro
中添加了相同的保持声明
对于 AndroidX:
-keep class androidx.lifecycle.** *;
支持:
-keep class android.arch.lifecycle.** *;
【讨论】:
这在我运行 Android Pie 的测试设备 (Pixel 3) 上没有发生,但是我在 Android Pie 设备上观察到了崩溃。 @straya 从 Google Playstore 安装时也会发生同样的情况。 :P【参考方案4】:将以下内容添加到您的 ProGuard 文件中。从 Android 架构组件 1.0.0 (source) 开始,这应该是不必要的,但显然它仍然是。
-keep class * implements android.arch.lifecycle.GeneratedAdapter <init>(...);
【讨论】:
这对我不起作用,但 Paul LeBeau 提供的更通用的解决方案成功了以上是关于RuntimeException:ClassNotFoundException android.arch.lifecycle.ProcessLifecycleOwnerInitializer的主要内容,如果未能解决你的问题,请参考以下文章