现在的位置: 首页 > 综合 > 正文

ANR—android程序架构时必须考虑的问题

2018年06月09日 ⁄ 综合 ⁄ 共 999字 ⁄ 字号 评论关闭

一、什么是ANR

ANR(application not responding):应用程序无响应。

ANR定义:在Android上,如果你的应用程序有一段时间响应不够灵敏,系统会向用户显示一个对话框,这个对话框称作应用程序无响应(ANR:Application Not Responding)对话框。用户可以选择“等待”而让程序继续运行,也可以选择“强制关闭”。所以一个流畅的合理的应用程序中不能出现anr,而让用户每次都要处理这个对话框。因此,在程序里对响应性能的设计很重要,这样系统不会显示ANR给用户。

二、产生原因

1、activity 5秒钟内没有响应输入的事件(如键盘按下,触摸屏幕)。

2、BroadcastReceiver 10秒钟内没有执行完相应的处理

造成的原因:在主线程中进行了非常耗时的工作:如网络连接、文件操作、数据操作、图片处理、复杂算法等。

三、如何避免ANR

1、activity的主线程中,潜在耗时的工作,在子线程中处理,处理完后发送消息给主线程。处理方法:

      A、在主线程中new出一个Handler以及实现处理消息函数:   Handler handler = new Handler() {public void handleMessage(Message msg){}}

      B、 创建一个子线程处理耗时工作:

      Thread thread = new Thread(){ public void run(){....此处进行耗时工作}}

       thread.start();

      C、在子线程run函数内的耗时工作完成后,通过Handler发送消息:handler.sendMessage()

      D、Handler接收处理消息,进行更新UI等相关工作。

2、对于BroadcastReceiver不能通过线程的方式处理,对于耗时的工作,要在广播接收处理函数(onReceive())中启动一个服务来处理。

3、避免在Intent Receiver里启动一个Activity,因为它会创建一个新的画面,并从当前用户正在运行的程序上抢夺焦点。如果你的应用程序在响应Intent广播时需要向用户展示什 么,你应该使用Notification Manager来实现。

四、出现ANR如何排查

在程序运行时,出现了ANR,工程师应该通过/data/anr/traces.txt并结合代码,进行ANR的分析。

抱歉!评论已关闭.