- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的 Android 应用程序收到有关 ANR keyDispatchingTimedOut 的错误报告。令人惊讶的是,这份报告中的堆栈跟踪不包含任何我自己的类。
我还检查了我的 onPause() 和 onResume() 方法,它们应该不需要很长时间。只是完成了一些资源清理,对于 onPause() 我希望最坏情况下的最大值为 1 秒(但完全由 必须 完成的事情导致,我会在其他地方创建内存泄漏。
我会在这里发布异常(exception)情况,可能有人知道它可能来自哪里:
DALVIK THREADS:
(mutexes: tll=0 tsl=0 tscl=0 ghl=0 hwl=0 hwll=0)
"main" prio=5 tid=1 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x400275d8 self=0xd050
| sysTid=1372 nice=0 sched=0/0 cgrp=default handle=-1345002112
| schedstat=( 11662176940194 5648544984518 10145639 )
at com.android.server.SystemServer.init1(Native Method)
at com.android.server.SystemServer.main(SystemServer.java:1073)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:607)
at dalvik.system.NativeStart.main(Native Method)
"DHCP Handler Thread" prio=5 tid=67 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40e9bfa8 self=0x19c6308
| sysTid=24486 nice=0 sched=0/0 cgrp=default handle=25164024
| schedstat=( 366210 41748048 6 )
at android.os.MessageQueue.nativePollOnce(Native Method)
at android.os.MessageQueue.next(MessageQueue.java:119)
at android.os.Looper.loop(Looper.java:127)
at android.os.HandlerThread.run(HandlerThread.java:60)
"WifiWatchdogThread" prio=5 tid=68 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x41244978 self=0x17dbef0
| sysTid=24466 nice=0 sched=0/0 cgrp=default handle=15264984
| schedstat=( 701905 7476806 13 )
at android.os.MessageQueue.nativePollOnce(Native Method)
at android.os.MessageQueue.next(MessageQueue.java:119)
at android.os.Looper.loop(Looper.java:127)
at com.android.server.WifiWatchdogService$WifiWatchdogThread.run (WifiWatchdogService.java:987)
"WifiMonitor" prio=5 tid=62 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x4131e810 self=0xd08208
| sysTid=24464 nice=0 sched=0/0 cgrp=default handle=12776888
| schedstat=( 333160420 1889770493 2621 )
at android.net.wifi.WifiNative.waitForEvent(Native Method)
at android.net.wifi.WifiMonitor$MonitorThread.run(WifiMonitor.java:203)
"android.hardware.SensorManager$SensorThread" prio=10 tid=41 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40fd23c8 self=0xb7fab0
| sysTid=12065 nice=-8 sched=0/0 cgrp=default handle=17642104
| schedstat=( 110688049235 273218872268 669479 )
at android.hardware.SensorManager.sensors_data_poll(Native Method)
at android.hardware.SensorManager$SensorThread$SensorThreadRunnable.run (SensorManager.java:457)
at java.lang.Thread.run(Thread.java:1027)
"Binder Thread #16" prio=5 tid=60 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40d10dd0 self=0x7b81d0
| sysTid=3142 nice=0 sched=0/0 cgrp=default handle=7991208
| schedstat=( 11422702482849 5701657716702 9785642 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #15" prio=5 tid=58 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40b781e0 self=0x806250
| sysTid=2769 nice=0 sched=0/0 cgrp=default handle=11040328
| schedstat=( 11575800474431 5698023835937 9772315 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #14" prio=5 tid=55 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40bf8fb0 self=0x4bb9d0
| sysTid=2753 nice=0 sched=0/0 cgrp=default handle=3581728
| schedstat=( 11386876678429 5731225067581 9692452 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #13" prio=5 tid=66 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40ba0b88 self=0x93b500
| sysTid=2087 nice=0 sched=0/0 cgrp=default handle=5284592
| schedstat=( 11618146360340 5720185427379 9899076 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #12" prio=5 tid=65 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40a9c6f0 self=0x551350
| sysTid=2051 nice=0 sched=0/0 cgrp=default handle=4866248
| schedstat=( 11450612946761 5715914702060 9837910 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #11" prio=5 tid=64 SUSPENDED
| group="main" sCount=1 dsCount=0 obj=0x40bc5890 self=0x757f70
| sysTid=2049 nice=0 sched=0/0 cgrp=default handle=8382088
| schedstat=( 11574565428602 5755652681331 9814613 )
at android.util.Log.println_native(Native Method)
at android.util.Slog.w(Slog.java:60)
at com.android.server.WifiService.getScanResults(WifiService.java:3184)
at android.net.wifi.IWifiManager$Stub.onTransact(IWifiManager.java:126)
at android.os.Binder.execTransact(Binder.java:320)
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #10" prio=5 tid=63 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40bbdcd0 self=0x551e40
| sysTid=2024 nice=0 sched=0/0 cgrp=default handle=9934888
| schedstat=( 11442461820647 5738453187888 9866071 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #9" prio=5 tid=61 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40a71b90 self=0x4f2148
| sysTid=2012 nice=0 sched=0/0 cgrp=default handle=7152360
| schedstat=( 11412723570422 5737569459835 9856082 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #8" prio=5 tid=59 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40a01fd8 self=0x60ca40
| sysTid=1628 nice=0 sched=0/0 cgrp=default handle=5809144
| schedstat=( 11483056913767 5750414339519 9921476 )
at dalvik.system.NativeStart.run(Native Method)
"pool-1-thread-1" prio=5 tid=57 WAIT
| group="main" sCount=1 dsCount=0 obj=0x40aec4e0 self=0x609538
| sysTid=1612 nice=0 sched=0/0 cgrp=default handle=5159248
| schedstat=( 3046508787 1064334014940 196511 )
at java.lang.Object.wait(Native Method)
- waiting on <0x40aec668> (a java.lang.VMThread)
at java.lang.Thread.parkFor(Thread.java:1443)
at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
at sun.misc.Unsafe.park(Unsafe.java:337)
at java.util.concurrent.locks.LockSupport.park(LockSupport.java:157)
at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await (AbstractQueuedSynchronizer.java:2022)
at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:411)
at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1021)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1081)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
at java.lang.Thread.run(Thread.java:1027)
"RefQueueWorker@org.apache.http.impl.conn.tsccm.ConnPoolByRoute@409f8528" daemon prio=5 tid=56 WAIT
| group="main" sCount=1 dsCount=0 obj=0x409f8730 self=0x7f49d0
| sysTid=1604 nice=0 sched=0/0 cgrp=default handle=7101040
| schedstat=( 1492370720 1062000579822 183346 )
at java.lang.Object.wait(Native Method)
- waiting on <0x4088bc80> (a java.lang.ref.ReferenceQueue)
at java.lang.Object.wait(Object.java:395)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:107)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:80)
at org.apache.http.impl.conn.tsccm.RefQueueWorker.run(RefQueueWorker.java:102)
at java.lang.Thread.run(Thread.java:1027)
"GpsLocationProvider" prio=5 tid=54 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40924278 self=0x5aac30
| sysTid=1593 nice=0 sched=0/0 cgrp=default handle=5213160
| schedstat=( 53695556564 4105485168504 314554 )
at android.os.MessageQueue.nativePollOnce(Native Method)
at android.os.MessageQueue.next(MessageQueue.java:119)
at android.os.Looper.loop(Looper.java:127)
at com.android.server.location.GpsLocationProvider$GpsLocationProviderThread.run (GpsLocationProvider.java:2627)
"GpsNetwork" prio=5 tid=53 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40918f30 self=0x7a3280
| sysTid=1592 nice=10 sched=0/0 cgrp=bg_non_interactive handle=5596240
| schedstat=( 3941528407 4715350128138 190744 )
at android.os.MessageQueue.nativePollOnce(Native Method)
at android.os.MessageQueue.next(MessageQueue.java:119)
at android.os.Looper.loop(Looper.java:127)
at com.android.server.location.GpsLocationProvider$GpsNetworkThread.run (GpsLocationProvider.java:2640)
"pd_api_DeferredActionThread" prio=5 tid=52 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x4091ff60 self=0x60a838
| sysTid=1590 nice=0 sched=0/0 cgrp=default handle=8651504
| schedstat=( 457944183704 2556608550419 1632941 )
at dalvik.system.NativeStart.run(Native Method)
"RefQueueWorker@org.apache.http.impl.conn.tsccm.ConnPoolByRoute@4094f298" daemon prio=5 tid=51 WAIT
| group="main" sCount=1 dsCount=0 obj=0x409ccd20 self=0x4db280
| sysTid=1575 nice=0 sched=0/0 cgrp=default handle=5202200
| schedstat=( 1599853387 1042935485993 183397 )
at java.lang.Object.wait(Native Method)
- waiting on <0x408ddf60> (a java.lang.ref.ReferenceQueue)
at java.lang.Object.wait(Object.java:395)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:107)
at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:80)
at org.apache.http.impl.conn.tsccm.RefQueueWorker.run(RefQueueWorker.java:102)
at java.lang.Thread.run(Thread.java:1027)
"Binder Thread #7" prio=5 tid=50 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40923718 self=0x4db8d0
| sysTid=1573 nice=0 sched=0/0 cgrp=default handle=8114928
| schedstat=( 12123622466944 5905026153897 10044543 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #6" prio=5 tid=49 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x4095ddf8 self=0x4f84a8
| sysTid=1572 nice=0 sched=0/0 cgrp=default handle=7427944
| schedstat=( 11386062986105 5713769168163 9948969 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #5" prio=5 tid=48 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x4098e360 self=0x7fb658
| sysTid=1571 nice=0 sched=0/0 cgrp=default handle=8364584
| schedstat=( 12129762418333 5854713838622 10020470 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #4" prio=5 tid=47 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x409c3738 self=0x7866a8
| sysTid=1570 nice=0 sched=0/0 cgrp=default handle=7592008
| schedstat=( 11479118193718 5704348663883 9891752 )
at dalvik.system.NativeStart.run(Native Method)
"Binder Thread #3" prio=5 tid=46 NATIVE
| group="main" sCount=1 dsCount=0 obj=0x40ac0908 self=0x5ae448
| sysTid=1569 nice=0 sched=0/0 cgrp=default handle=6764560
| schedstat=( 12284007139602 5890366395349 10076640 )
at dalvik.system.NativeStart.run(Nat...
最佳答案
我对此的发现(但我不太确定):当我自己的应用程序中的某些内容阻塞时间过长时,就会发生这种情况。因此,当 onPause()/onResume() 等待太长时间直到返回调用者时,可能会发生超时。
我不知道的是:这个超时是多长时间,意味着一个应用程序可以拥有这些方法多长时间来执行一些内部任务......
关于android - ANR keyDispatchingTimedOut 但堆栈跟踪中没有自己的类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11493222/
我在我的开发控制台中收到了 ANR 错误的报告。我是否需要在我的服务中生成一个关闭 onSignalStrengthsChanged 的工作线程来停止长 sql 查询的 ANR? 我也不知道这是否是互
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法找出我的应用程序在哪里抛出了 ANR(应用程序无响应)。我查看了/data 中的 traces.txt 文件,并看到了我的应用程序的跟踪。这就是我在跟踪中看到的。 DALVIK THREAD
我们的应用有时会在设备前台停留很长时间(例如整夜)后,才使用ANR进行锁定。该应用程序启动,但仅显示黑屏。 “返回”和“主页”按钮在被按下大约10秒钟后才响应。 在严格模式下运行该应用程序不会突出显示
是否有可能在客户端知道在之前启动应用程序时是否发生过 ANR? 例如,用户使用某个应用程序 10 天,在第 10 天发生 ANR 并关闭应用程序,在第 11 天用户再次打开该应用程序,此时是否可以知道
我的应用程序中经常出现以下 ANR Input dispatching timed out (Waiting to send key event because the focused window
是否有可能在客户端知道在之前启动应用程序时是否发生过 ANR? 例如,用户使用某个应用程序 10 天,在第 10 天发生 ANR 并关闭应用程序,在第 11 天用户再次打开该应用程序,此时是否可以知道
为什么我不能强制使用 Android ANR用这个代码?没有日志消息或弹出窗口。该应用程序刚刚延迟启动。 [更新] 即使休眠 View.setOnClickListener 或 BroadcastRe
我在调试我的应用程序时遇到问题。这是一个数据收集应用程序,每个“作业”大约需要 15 分钟才能完成,其中快速连续完成多个作业是一个正常用例。 我看到的症状如下: 应用程序运行 20 到 90 分钟后,
背景: 这个应用程序是一个简单的 Wifi 管理器,收集/扫描并在 ListView 中显示结果。由于此扫描按间隔进行扫描,因此我创建了一个线程并在扫描之间设置了 Thread.sleep(inter
我有一个在 Sqlite 数据库上运行查询、获取游标、使用该游标创建 CustomCursorAdapter 并将其附加到 Activity 中的 ListView 的 Activity 。它看起来像
分析 ANR 堆栈跟踪 我看到 utm 和 stm 键。甚至在 developers.android.com 上也找不到信息来理解那些的含义。有没有人知道与这些 key 相关的知识? "main" p
我有一个 IntentService,用于将日志发送到我们的日志服务器。 我已经收到有关此应用程序在现场无缘无故退出的报告,没有 ANR,没有“不幸......”,只是无声的“崩溃到桌面”(这不是“崩
我的一般问题是 - 如何让后台服务在每个“INTERVAL”运行而不收到 ANR 消息(尝试制作从 alarmManager 调用的服务,它启动一个线程来完成它的工作)?感谢您的帮助! 更具体: 我正
我前段时间写的一个游戏有 ANR 问题,调试表明它们是 HTTP 请求花费很长时间(因此导致 ANR)。 我认为通过将 HTTP 代码分配到从处理程序中调用的 Runnable 中,我可以避免 ANR
我有一个简单的应用程序,它读取互联网资源并以 ImageView 和 TextView 的形式在小部件或 ListView Activity 中显示信息。除了从 Internet 下载数据外,它还会在
我的应用程序允许将段落发送到 TTS 引擎并将其排队。想一本书,你长按一个段落,它以 QUEUE 模式发送到 TTS 引擎。 这在 Android 之前的 Jelly bean 中总是完美运行,但是在
输入调度超时(等待,因为没有窗口有焦点,但有一个焦点应用程序可能最终在完成启动时添加一个窗口。) 嗨!我从几个用户那里收到了这份奇怪的 ANR 报告。不幸的是,我对 ANR 报告的了解非常有限,我希望
当我开始我的 Activity 时,我收到一个 ANR 错误。我不知道如何修复,我认为这个错误是由事件引起的。 这是错误: 01-23 12:29:29.594: E/ActivityMana
如果我从一个正在运行的 Activity 开始一个新的 Activity,我会一直收到 ANRs有时有一个 SurfaceView。有谁知道这个锁是干什么用的?我使用安卓支持包要使用 fragment
我是一名优秀的程序员,十分优秀!