从BroadcastReceiver中anr重新认识

来源:互联网 发布:大连u盘数据恢复公司 编辑:程序博客网 时间:2024/06/16 08:01

参考文章:

android 直接在activity/broadcast receiver中启动子线程来处理长时间的耗时任务不行吗?

Android中的ANR用法详解

昨天处理项目中的一个功能时遇到一个问题,是在receiver中进行复杂的耗时操作,当然其中包括上传数据等等,然后就anr,但是anr的实际很令我费解明明是10s内绝对能完成的,然后在将近10秒时开了个子线程进行其他操作。然而实际上子线程中的任务一直无法正常执行,看了下错误anr

然后解决办法将部分耗时操作转移至intentservice中,然后计时操作选择timertask,虽然用

new MCountDownTimer2(10000, 10000);
这种方式也可以实现计时的作用,虽然很不对口,但是在主线程ok,在worker thread显然是不行的。

虽然其中一个耗时操作在intentservice经验证就2s,在receiver里30s左右在中间anr

--------------------------------------------------------------------------------------------------------------------------------------------------------

如果开发者需要在Service处理耗时任务,建议在Service中另外启动一条新线程来处理该耗时任务.就像前面BindService中看到的,程序在BindService中的onCreate()方法中启动了一条新线程来处理耗时任务.可能有读者感到疑惑:直接在其他程序组件中启动子线程来处理耗时任务不行吗?这种方式也不可靠,由于activity可能会被用户退出,Broadcast Receiver的生命周期本身就很短.可能出现的情况是:在子线程还没有结束的情况下.Activity已经被用户退出了,或者BroadcastReceiver已经结束了.在Activity已经退出、BroadcastReceiver已经结束的情况下,此时它们所在的进程就变成了空进程(没有任何活动组件的进程),系统需要内存时可能会优先终止该进程.如果宿主进程被终止,那么该进程内的所有子线程也会被中止,这样就可能导致子线程无法执行完成.



摘自:疯狂Android讲义 第二版 pdf P495

0 0