Android Broadcast timeout
来源:互联网 发布:新加坡留学 知乎 编辑:程序博客网 时间:2024/06/06 08:46
Broadcast timeout
Brocadcast timeout 是指串行有序广播发送给receiver的时候,app没有来得及处理这个广播,或者app的receiver处理这个广播的时候超时了(前台广播10s,后台广播60s),没有及时回调finishReceiver通知fw。并行无序广播不计算timeout。
普通情况下的broadcast timeout比较好分析,一般只有3种情况:
1) 主线程很忙,没来得及处理。
这种情况我们通过主线程log就可以判断,主线程log不停止,一直在打印,就说明主线程没有卡住,此时发生的anr大都是因为主线程忙导致的。
2) 主线程卡住,没来及处理。
这种现象比较明显,主线程在某一时刻停止打印log,再结合trace,就可以判断hang住的点。
3) onReceive处理时间过长。这个case分两种:
a)onReceive处理时间长。
这种情况也比较好处理,看主线程trace就可以定论。
b)onReceive中call goAsync转移到其他线程处理,然后卡在其他线程。
这种情况比较复杂,goAsync只是把事情放到其他线程,避免block主线程,但是timeout计时依然不停止,要等工作线程处理完call finish以后才算处理完broadcast。不call goAsync直接起子线程处理广播事物会让系统误认为你以外处理完广播,从而降低进程优先级,导致进程被kill,继而导致广播不能完整处理完。对于事情不算特别复杂,能在60s(前台10s)之内肯定完成的工作,通过这种方式可以有更好的体验。但是对于超过60s(前台10s)的事务还是要起service来处理。
这类问题分析的时候,主线程显示不忙,trace显示主线程有没有hang,但是就是timeout,这时候就要去看那个工作线程的trace是不是block住了。
- Android ANR-Broadcast Timeout
- Android Broadcast timeout
- ANR源码分析之Broadcast Timeout
- Android BroadCast
- Android Broadcast
- android broadcast
- android broadcast
- Android Broadcast
- android - broadcast
- android broadcast
- 【Android】Broadcast
- Android BroadCast
- Android broadcast
- Android - Broadcast
- android broadcast
- android broadcast
- Android Broadcast
- Android Broadcast
- html5获取自己定位的方法
- u3d目标与摄像机之间的遮挡物变为透明
- mysql乱码问题
- ionic状态改变时动态(强制)刷新页面
- Android 访问权限Permission详解
- Android Broadcast timeout
- Android短信发送流程之普通短信发送(原)
- 简述list,set,map集合
- MySQL explain
- 新的起点
- hdu 1159 Common Subsequence (最长公共子序列 +代码)
- nyoj202 红黑树 (二叉树的左旋右旋)
- 欢迎使用CSDN-markdown编辑器
- mysql定时任务和事件解决订单自动更新状态问题