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的主要内容,如果未能解决你的问题,请参考以下文章