【问题标题】:Android ActivityThread.reportSizeConfigurations causes app to freeze with black screen and then crashAndroid ActivityThread.reportSizeConfigurations 导致应用程序冻结并黑屏然后崩溃
【发布时间】:2018-02-28 18:28:11
【问题描述】:

我的应用程序崩溃了。它发生在很多用户及其在 ActivityThread.java 方法 reportSizeConfigurations 中的多个位置。我不知道这是做什么用的,为什么会冻结。

冻结发生在初始屏幕之后(主 Activity 启动时),并且仅在应用升级时发生。如果您重新安装应用程序,问题就会消失。问题是,我不能告诉所有用户重新安装应用程序...

有谁知道这可能是什么原因,为什么?它似乎可能与一些数据库处理有关,但这只是一个猜测。

这是来自 Crashlytics 的堆栈跟踪:

Fatal Exception: java.lang.IllegalArgumentException: reportSizeConfigurations: ActivityRecord not found for: Token{a28a055 null}
   at android.os.Parcel.readException(Parcel.java:1697)
   at android.os.Parcel.readException(Parcel.java:1646)
   at android.app.ActivityManagerProxy.reportSizeConfigurations(ActivityManagerNative.java:8342)
   at android.app.ActivityThread.reportSizeConfigurations(ActivityThread.java:3049)
   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2992)
   at android.app.ActivityThread.-wrap14(ActivityThread.java)
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1631)
   at android.os.Handler.dispatchMessage(Handler.java:102)
   at android.os.Looper.loop(Looper.java:154)
   at android.app.ActivityThread.main(ActivityThread.java:6682)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1520)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1410)

这是来自 Play 商店“ANR 和崩溃”的堆栈跟踪:

    "main" prio=5 tid=1 TimedWaiting
  | group="main" sCount=1 dsCount=0 obj=0x74864f70 self=0x7f8b896a00
  | sysTid=28578 nice=0 cgrp=default sched=0/0 handle=0x7f8f832a98
  | state=S schedstat=( 237746089 66838748 1069 ) utm=18 stm=5 core=6 HZ=100
  | stack=0x7fcdbf9000-0x7fcdbfb000 stackSize=8MB
  | held mutexes=

  at java.lang.Object.wait! (Native method)
- waiting on <0x0c54fb7b> (a java.lang.Object)
  at java.lang.Thread.parkFor$ (Thread.java:2127)
- locked <0x0c54fb7b> (a java.lang.Object)
  at sun.misc.Unsafe.park (Unsafe.java:325)
  at java.util.concurrent.locks.LockSupport.parkNanos (LockSupport.java:201)
  at android.database.sqlite.SQLiteConnectionPool.waitForConnection (SQLiteConnectionPool.java:670)
  at android.database.sqlite.SQLiteConnectionPool.acquireConnection (SQLiteConnectionPool.java:348)
  at android.database.sqlite.SQLiteSession.acquireConnection (SQLiteSession.java:894)
  at android.database.sqlite.SQLiteSession.prepare (SQLiteSession.java:586)
  at android.database.sqlite.SQLiteProgram.<init> (SQLiteProgram.java:58)
  at android.database.sqlite.SQLiteQuery.<init> (SQLiteQuery.java:37)
  at android.database.sqlite.SQLiteDirectCursorDriver.query (SQLiteDirectCursorDriver.java:44)
  at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory (SQLiteDatabase.java:1318)
  at android.database.sqlite.SQLiteQueryBuilder.query (SQLiteQueryBuilder.java:399)
  at android.database.sqlite.SQLiteQueryBuilder.query (SQLiteQueryBuilder.java:294)
  at com.norwegian.travelassistant.managers.storagemanager.StorageManager.query (StorageManager.java:1011)
  at com.norwegian.travelassistant.managers.storagemanager.StorageManager.a (StorageManager.java:1218)
- locked <0x00f0bd98> (a java.lang.Object)
  at com.norwegian.travelassistant.managers.storagemanager.StorageManager.a (StorageManager.java:1205)
  at com.norwegian.travelassistant.managers.storagemanager.StorageManager.F (StorageManager.java:1812)
  at com.norwegian.travelassistant.managers.e.a (LanguageManager.java:63)
  at com.norwegian.travelassistant.managers.e.a (LanguageManager.java:84)
  at com.norwegian.travelassistant.tabbar.TabsActivity.onCreate (TabsActivity.java:141)
  at android.app.Activity.performCreate (Activity.java:6705)
  at android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1119)
  at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2664)
  at android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2772)
  at android.app.ActivityThread.-wrap12 (ActivityThread.java)
  at android.app.ActivityThread$H.handleMessage (ActivityThread.java:1515)
  at android.os.Handler.dispatchMessage (Handler.java:102)
  at android.os.Looper.loop (Looper.java:241)
  at android.app.ActivityThread.main (ActivityThread.java:6217)
  at java.lang.reflect.Method.invoke! (Native method)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:865)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:755)

如果您需要更多信息,请告知

【问题讨论】:

  • 似乎它连接到主线程中的数据库 I/O。我以前从来没有遇到过这个问题,但也许有些事情已经改变了......
  • 我的解决方法是删除并重新实例化数据库。一个丑陋的修复,但它的工作。似乎很多用户在发布时都损坏了数据库。为什么,我不知道...

标签: android crash crashlytics


【解决方案1】:

崩溃是由您的服务上的 ANR 引起的,在您的 Activity 启动之前。

如果用户在服务中的长时间运行任务期间启动您的应用,则在服务上的任务完成之前不会创建 Activity。对于启动您的应用的用户来说,这种等待可能看起来很奇怪,然后他们在任务切换器中滑动您的应用,这会从 ActivityManager 中删除任务记录(但此时进程仍然保持活动状态)。

当服务上长时间运行的任务最终返回时,它会解除对活动启动的阻塞,但此时活动会抛出ActivityRecord not found异常,因为它已经被移除了。

下面的序列图可能更好地解释崩溃。

感谢 YogiAi,他最初在 this post 调查了这个问题。

【讨论】:

  • 我认为这不是我的问题。如果您只是等待了很长时间,应用程序就会崩溃。即使您没有“杀死”或“刷卡”应用程序。重新启动数据库有效,因此数据库以某种方式损坏,当我尝试访问它时,应用程序冻结并崩溃。我不知道为什么...
  • 分享帖子需要付费才能阅读全文,帮助不大。
  • 我无法打开链接。有解决这个问题的经验吗?
  • 如果我在活动的onCreate() 中调用finish() 会出现问题吗?
  • 所以这个问题存在,现在不是了吗?要不然是啥?有没有解决方法?似乎至少要等到 Android 9...
【解决方案2】:

Google 发现了一个错误,似乎是三星独有的应用升级

https://issuetracker.google.com/issues/62427912

【讨论】:

  • 在运行 Android 9 的三星 Galaxy J8 上面临同样的问题。
  • 我只在 Android 9 中得到了这个
  • 我在华为设备上也有这个。真的修好了?来自哪个 Android 版本?
  • 我在搭载 Android 8.1.0 的华为 nova 3i 上获得了它。这是一种罕见的崩溃,似乎在设备处于后台状态时发生。但修复会很有用。
【解决方案3】:

此问题的原因之一可能是 - 内存泄漏。 在 Houde 的blog 中,他编写了一个使用 EventBus 接收事件以关闭 Activity 的应用程序,并且一个 Event 正在编写一个内部类,这是由内存泄漏引起的。

内存泄漏导致活动不是没有启动而是重新启动。他的话引起了问题。

另一个problem 可能是活动暂停/停止/销毁超时。它可以导致相同的

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-11-27
    • 1970-01-01
    • 2014-05-08
    相关资源
    最近更新 更多