Thread,intentservice、Asynctask
ANR问题的解析
在 Android 中,活动管理器和窗口管理器这两个系统服务负责监视应用程序的响应。当出现下列情况时, Android 就会显示 ANR 对话框了:
对输入事件 ( 如按键、触摸屏事件 ) 的响应超过 5 秒
意向接受器 (intentReceiver) 超过 10 秒钟仍未执行完毕
Android应用程序完全运行在一个独立的线程中(例如main)。这就意味着,任何在主线程中运行的,需要消耗大量时的操作都会引发ANR。因为此时,你的应用程序已经没有机会去响应输入事件和意向广播(Intent broadcast)。
因此,任何运行在主线程中的方法,都要尽可能的只做少量的工作。特别是活动生命周期中的重要方法如onCreate()和 onResume()等更应如此。潜在的比较耗时的操作,如访问网络和数据库;或者是开销很大的计算,比如改变位图的大小,需要在一个单独的子线程中完成(或者是使用异步请求,如数据库操作)。但这并不意味着你的主线程需要进入阻塞状态已等待子线程结束 -- 也不需要调用Therad.wait()或者Thread.sleep()方法。取而代之的是,主线程为子线程提供一个句柄(Handler),让子线程在即将结束的时候调用它(xing:可以参看Snake的例子,这种方法与以前我们所接触的有所不同)。使用这种方法涉及你的应用程序,能够保证你的程序对输入保持良好的响应,从而避免因为输入事件超过5秒钟不被处理而产生的ANR。这种实践需要应用到所有显示用户界面的线程,因为他们都面临着同样的超时问题。
1 、什么是 ANR?
ANR:Application Not Responding ,即应用无响应 ,就是说应用程序在 5S内没有响应。
2 、
为什么会 ANR?
(1)当前的事物发生堵塞,没有被执行。比如说 UI 线程中处理耗时的操作,发生线程的堵塞
(2)当前事物正在被执行,而没有被完全执行。
3 、 ANR 的分类:(1) 按键或触摸事件在 5S 内 没有 响应
(2)BroadcastReceiver在特定时间内无法处理完成(BroadcastTimeout)
(3)Service在特定的时间内无法处理完成(ServiceTimeout)
4 、如何尽量去避免 ANR 的出现
一般 ANR 多是因为线程堵塞照成的,比如说 UI 线程去处理很耗时的操作(数据库,网络的连接,下载等类似的操作),
所以要避免此类问题的出现。
(1) UI 线程尽量只做跟 UI 相关的工作 。
(2)耗时的操作可以开启一个新的线程,或者是后台去处理。
5、
有哪些 UI 线程?
Activity:onCreate(), onResume(), onDestroy(), onKeyDown(), onClick()
AsyncTask: onPreExecute(), onProgressUpdate(), onPostExecute(), onCancel,
Mainthread handler: handleMessage(), post*(runnable r)
子线程: