最近我的应用程序开始在预发布报告中包含奇怪的错误消息(上传到Play商店后自动生成)。
这些报告包含以下例外情况:
Exception java.lang.NoSuchMethodError: No interface method a(Landroid/arch/lifecycle/e;Landroid/arch/lifecycle/b$a;)V in class Landroid/arch/lifecycle/GenericLifecycleObserver; or its super classes (declaration of 'android.arch.lifecycle.GenericLifecycleObserver' appears in /data/app/com.google.android.apps.mtaas.crawler-1/base.apk)
android.arch.lifecycle.f$a.a (f.java:326)
android.arch.lifecycle.f.a (f.java:159)
com.firebase.ui.database.FirebaseRecyclerAdapter.<init> (FirebaseRecyclerAdapter.java:40)
和
Exception java.lang.NoSuchMethodError: No static method a(Landroid/app/Activity;)V in class Landroid/arch/lifecycle/ReportFragment; or its super classes (declaration of 'android.arch.lifecycle.ReportFragment' appears in /data/app/com.google.android.apps.mtaas.crawler-1/base.apk)
android.arch.lifecycle.LifecycleDispatcher$DispatcherActivityCallback.onActivityCreated (LifecycleDispatcher.java:77)
android.app.Application.dispatchActivityCreated (Application.java:219)
android.app.Activity.onCreate (Activity.java:1040)
android.support.v4.app.SupportActivity.onCreate (SupportActivity.java:66)
android.support.v4.app.FragmentActivity.onCreate (FragmentActivity.java:285)
android.support.v7.app.AppCompatActivity.onCreate (AppCompatActivity.java:84)
和
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'int android.arch.core.internal.SafeIterableMap.size()' on a null object reference
at android.arch.lifecycle.LifecycleRegistry.getObserverCount(LifecycleRegistry.java:204)
at android.arch.lifecycle.ProcessLifecycleOwner.b(ProcessLifecycleOwner.java:154)
at android.arch.lifecycle.ProcessLifecycleOwner.a(ProcessLifecycleOwner.java:100)
at android.arch.lifecycle.LifecycleRuntimeTrojanProvider.onCreate(LifecycleRuntimeTrojanProvider.java:36)
at android.content.ContentProvider.attachInfo(ContentProvider.java:1751)
at android.content.ContentProvider.attachInfo(ContentProvider.java:1726)
at android.app.ActivityThread.installProvider(ActivityThread.java:6031)
... 10 more
奇怪的是,我发布的应用程序似乎在真实设备上正常运行(仅在启动前测试期间出现例外情况)。
我试图恢复自上次构建以来我没有预启动问题所执行的所有(主要)更改:从API 26返回到API 27,旧版本的支持库,没有D8等,但没有成功到目前为止:在执行的9个测试中,只有1个或2个成功,其余的都因此类错误而失败。
我该怎么做才能解决这个问题?
答案 0 :(得分:5)
刚从Google Play开发人员支持中获得答案。他们正在调查这个问题。
作为一种解决方法,您可以通过选择退出新发布的版本来回溯到以前版本的抓取工具。
以下是选择退出的方式:
此后,再次正确显示启动报告。
PS - 这将禁用Google Play完成的默认测试,您可能会错过其他原因造成的任何其他错误。因此,请务必在投入生产之前实施自己的测试。
答案 1 :(得分:0)
Gson错误是由回归引起的。该问题已解决。在一两天内发布此修补程序后,它应该可以正常工作。