Android Looper停止处理导致ANR

Context

  • 所有Thread正常运行,没有锁的阻塞,没有死循环. (debug时,直接计suspend thread,查看栈的调用情况)
  • 根据Trace文件分析 CPU资源上,当前APP的线程中 主线程3%左右
  • 按back键,系统无法响应ANR
  • 最关键是主UI没有卡顿, ANR后显示是native状态. debug识图Thread中是RUNNING状态.方法栈在中nativePollOnce.

情景

  1. 相机类型APP,为提高速度,一个周期为 50~60ms
  2. 为了统计处理时间, 显示图像处理耗时

验证

  1. anr后的trace文件 (看Thread的信息,CPU的使用情况)
  2. Profiler,(CPU栏: 看Thread的调用,Memory栏 看对象的创建,当前状态)

最后原因

是在子线程 textView.setText("Test")调用频繁导致的. 设置间隔为50ms左右.

拓展

以前,Android如果子线程操作UI是直接崩溃的啊!郁闷死我了,我看看StrictMode是不是可以杜绝

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值