当前位置: 首页 > news >正文

android ANR产生原因和解决办法

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

    默认情况下,在android中Activity的最长执行时间是5秒,BroadcastReceiver的最长执行时间则是10秒。

第一:什么会引发ANR?

 

     在Android里,应用程序的响应性是由Activity Manager和WindowManager系统服务监视的 。当它监测到以下情况中的一个时,Android就会针对特定的应用程序显示ANR:

1.在5秒内没有响应输入的事件(例如,按键按下,屏幕触摸)
2.BroadcastReceiver在10秒内没有执行完毕

3.service是20

造成以上两点的原因有很多,比如在主线程中做了非常耗时的操作,比如说是下载,io异常等。

   

    潜在的耗时操作,例如网络或数据库操作,或者高耗时的计算如改变位图尺寸,应该在子线程里(或者以数据库操作为例,通过异步请求的方式)来完成。然而,不是说你的主线程阻塞在那里等待子线程的完成——也不是调用 Thread.wait()或是Thread.sleep()。替代的方法是,主线程应该为子线程提供一个Handler,以便完成时能够提交给主线程。以这种方式设计你的应用程序,将能保证你的主线程保持对输入的响应性并能避免由于5秒输入事件的超时引发的ANR对话框。

 

第二:如何避免ANR?

 

1、运行在主线程里的任何方法都尽可能少做事情。特别是,Activity应该在它的关键生命周期方法(如onCreate()和onResume())里尽可能少的去做创建操作。(可以采用重新开启子线程的方式,然后使用Handler+Message的方式做一些操作,比如更新主线程中的ui等)

 

2、应用程序应该避免在BroadcastReceiver里做耗时的操作或计算。但不再是在子线程里做这些任务(因为 BroadcastReceiver的生命周期短),替代的是,如果响应Intent广播需要执行一个耗时的动作的话,应用程序应该启动一个 Service。(此处需要注意的是可以在广播接受者中启动Service,但是却不可以在Service中启动broadcasereciver,关于原因后续会有介绍,此处不是本文重点)

 

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

 

dub总结:anr异常也是在程序中自己经常遇到的问题,主要的解决办法自己最常用的就是不要在主线程中做耗时的操作,而应放在子线程中来实现,比如采用Handler+mesage的方式,或者是有时候需要做一些和网络相互交互的耗时操作就采用asyntask异步任务的方式(它的底层其实Handler+mesage有所区别的是它是线程池)等,在主线程中更新UI。

相关文章:

  • Handler的作用与用法,handler在Thread中传递,Activity像service 传递信息:使用广播
  • java中创建线程的三种方法
  • java环境搭建,jdk和jre的区别,android studio安装
  • Android Studio 常用快捷方式
  • svn初步安装以及使用
  • Android Studio 连接真机不识别
  • 什么是Retrofit? 使用Retrofit MediaType的详细介绍
  • 学习方式
  • telnet 和ping区别 笔记本无线打叉首先点击开始,打开控制版面。
  • 2018年Android最新面试题
  • 关于 Android 进程保活,你所需要知道的一切
  • 考研经验总结
  • 管态和目态,转换方式,中断之系统调用
  • 中断可分为三类 概述: 硬件中断 软中断 硬件中断和软中断的区别: 1. 死锁:死锁是指多个进程相互等待,互不相让,导致所有进等程无限期待。 原语 中断、异常和系统调用的关系 1.中断的
  • 系统调用解释,同步和互斥,操作系统原理(时间片,抢占式),Thread.Sleep作用,Thread.sleep 的Thread是指的当前所在的线程,Thread.Sleep(0)的作用
  • 【翻译】Mashape是如何管理15000个API和微服务的(三)
  • C语言笔记(第一章:C语言编程)
  • js作用域和this的理解
  • LeetCode541. Reverse String II -- 按步长反转字符串
  • mysql innodb 索引使用指南
  • Selenium实战教程系列(二)---元素定位
  • vue:响应原理
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 将回调地狱按在地上摩擦的Promise
  • 讲清楚之javascript作用域
  • 使用 QuickBI 搭建酷炫可视化分析
  • 思维导图—你不知道的JavaScript中卷
  • 我看到的前端
  • Mac 上flink的安装与启动
  • # 学号 2017-2018-20172309 《程序设计与数据结构》实验三报告
  • #if 1...#endif
  • (¥1011)-(一千零一拾一元整)输出
  • (02)Hive SQL编译成MapReduce任务的过程
  • (DFS + 剪枝)【洛谷P1731】 [NOI1999] 生日蛋糕
  • (pojstep1.1.1)poj 1298(直叙式模拟)
  • (力扣记录)1448. 统计二叉树中好节点的数目
  • (原创) cocos2dx使用Curl连接网络(客户端)
  • (原創) 如何使用ISO C++讀寫BMP圖檔? (C/C++) (Image Processing)
  • (转)linux 命令大全
  • .NET / MSBuild 扩展编译时什么时候用 BeforeTargets / AfterTargets 什么时候用 DependsOnTargets?
  • .NET 除了用 Task 之外,如何自己写一个可以 await 的对象?
  • .NET 设计模式—适配器模式(Adapter Pattern)
  • .Net8 Blazor 尝鲜
  • .NET处理HTTP请求
  • .net打印*三角形
  • .NET应用架构设计:原则、模式与实践 目录预览
  • .NET中的Exception处理(C#)
  • @PreAuthorize注解
  • @RequestMapping用法详解
  • [ 渗透工具篇 ] 一篇文章让你掌握神奇的shuize -- 信息收集自动化工具
  • [Android实例] 保持屏幕长亮的两种方法 [转]
  • [BUUCTF]-PWN:wustctf2020_number_game解析(补码,整数漏洞)
  • [C#]OpenCvSharp使用帧差法或者三帧差法检测移动物体
  • [CSS]文字旁边的竖线以及布局知识
  • [Firefly-Linux] RK3568修改控制台DEBUG为普通串口UART