• UID5201
  • 登录2017-10-18
  • 粉丝2
  • 关注0
  • 发帖57
  • 主页
  • 金币285枚
Ifyou 发布于2017-07-13 17:41
0/175

Android性能测试之卡顿ANR测试

楼层直达


一直以来Android性能测试一直是android测试中一个被一部分人遗忘,有被一部分人无可奈何的东西。在绝大部分的创业公司,性能测试基本上都是被遗忘的,因为功能测试和稳定性测试才是重点,而在中等公司中一部分测试人员向对Android进行性能测试,却无从下手。Android性能测试一直存在测试维度少,测试数据难收集,已收集数据难量化的特点,这些特点又是因为Android手机版本碎片化、硬件多样化、App功能复杂造成的。
 
性能测试总的来说,可以分为卡顿ANR测试、流畅度测试、电量测试、流量测试。一个APP为什么需要性能测试,总的来说就是一些不严谨的代码,在低端机型造成卡顿,对手机上有限电量的浪费,昂贵流量的浪费,造成用户流失。
 
今天先说说卡顿ANR测试
 
卡顿ANRAndroid就是天生的朋友,从Android第一天诞生直到现在的8CPUAndroid还是未能摆脱页面不流畅,卡,死机的诟病,所以个人认为卡顿ANR测试是性能测试最主要的一块。
 
卡顿简单的来说,就是手机没有及时响应、页面延迟,出现丢帧的现象,或者点击无响应。绝大多数的卡顿,稍等片刻系统就会恢复正常,但假如超过5S,就可能会引发手机ANR,造成更高级别的警告。
 
什么会引发ANR
 
Android里,应用程序的响应性是由Activity ManagerWindowManager系统服务监视的 。当它监测到以下情况中的一个时,Android就会针对特定的应用程序显示ANR
ANR一般有三种类型:
 
1KeyDispatchTimeout(5
seconds) --主要类型按键或触摸事件在特定时间内无响应
2BroadcastTimeout(10
seconds) --BroadcastReceiver在特定时间内无法处理完成
3ServiceTimeout(20
seconds) --小概率类型 Service在特定的时间内无法处理完成
 
这三种原因都会造成ANR,但是第一种情况基本上占了所有ANR的百分之九十以上,第三种的情况微乎其微。这三种ANR不是孤立的,有可能会相互影响。例如一个应用程序进程中同时有一个正在显示的Activity和一个正在处理消息的BroadcastReceiver,它们都运行在这个进程的主线程中。如果BRonReceive函数没有返回,此时用户点击屏幕,而onReceive超过5秒仍然没有返回,主线程无法处理用户输入事件,就会引起第1ANR。如果继续超过10秒没有返回,又会引起第2ANR。发生ANR的主要原因是潜在的耗时操作,例如网络或数据库操作,或者高耗时的计算如改变位图尺寸,应该在子线程里(或者以数据库操作为例,通过异步请求的方式)来完成。然而,不是说你的主线程阻塞在那里等待子线程的完成——也不是调用 Thread.wait()或是Thread.sleep()。替代的方法是,主线程应该为子线程提供一个Handler,以便完成时能够提交给主线程。以这种方式设计你的应用程序,将能保证你的主线程保持对输入的响应性并能避免由于5秒输入事件的超时引发的ANR对话框。
 
三种ANR发生时都会在log中输出错误信息,你会发现各个应用进程和系统进程的函数堆栈信息都输出到了一个/data/anr/traces.txt的文件中,ROOT手机导出该文件后,分析此日志可以得出一些结论,但traces文件信息比较抽象,难理解。总的来说,日志难收集,结果难分析。
 
如何避免ANR
 
1 运行在主线程里的任何方法都尽可能少做事情。特别是,Activity应该在它的关键生命周期方法(如onCreate()onResume())里尽可能少的去做创建操作。(可以采用重新开启子线程的方式,然后使用Handler+Message的方式做一些操作,比如更新主线程中的ui等)
 
2 应用程序应该避免在BroadcastReceiver里做耗时的操作或计算。但不再是在子线程里做这些任务(因为 BroadcastReceiver的生命周期短),替代的是,如果响应Intent广播需要执行一个耗时的动作的话,应用程序应该启动一个 Service。(此处需要注意的是可以在广播接受者中启动Service,但是却不可以在Service中启动broadcasereciver,关于原因后续会有介绍,此处不是本文重点)
 
3)避免在Intent Receiver里启动一个Activity,因为它会创建一个新的画面,并从当前用户正在运行的程序上抢夺焦点。如果你的应用程序在响应Intent广 播时需要向用户展示什么,你应该使用Notification Manager来实现。
 
TestBird

0人打赏
您需要登录后才可以回帖
发表回复
极贡献
技术问答
专题荟萃
程序人生
视觉设计
Android开发
iOS开发
编程语言
前端开发
后端开发
服务器架构
软件测试
运维方案
创业路上



最热文章墙

  • 79416/378   【精品推荐】200多种Android动画效果的强悍框架,太全了,不看这个,再有动画的问题,不理你了^@^

  • 45307/191   情人节福利,程序员表白的正确姿势:改几行代码就变成自己的表白了

  • 44993/0   Python爬虫:常用浏览器的useragent

  • 41475/260   【精品推荐】Android版产品级的音乐播放器源码,功能太强大了,最好的产品原型有木有?

  • 38687/145   省时省力的Android组件群来了,非常棒的原型参考

  • 30063/142   2016抢红包软件及源码

  • 29299/2   超全!整理常用的iOS第三方资源

  • 29290/71   原创表白APP,以程序员的姿势备战新年后的7夕,持续完善中!

  • 24355/160   Android版类似UC浏览器:非常赞,产品级的源码

  • 22870/30   麻省理工的一帮疯子,真的实现了随意操控万物!(绝对黑科技)

  • 22568/25   Android工程师面试题大全

  • 22494/27   2016程序员跳槽全攻略

  • 21954/9   GitHub上排名前50的iOS项目:总有一款你用得着

  • 20912/20   码魂:程序员的牛B漫画

  • 19065/85   Android小而全的博客源码:非常适合全面掌握开发技巧

  • 19055/73   【持续更新中】Android福利贴(二):资料源码大放送

  • 19019/10   2016年最全的Android面试考题+答案 精编版

  • 18922/42   一个绚丽的loading动效分析与实现!

  • 18765/3   吐槽那些程序员的搞笑牛逼注释

  • 17642/45   惊艳的App引导页:背景图片切换加各个页面动画效果

  • 17633/1   iOS 动画总结

  • 17511/82   仿京东商城客户端Android最新版,不错的原型和学习资料

  • 17472/104   Android带弹幕的视频播放器源码,来自大名鼎鼎的Bilibili弹幕网站

  • 17150/23   个人收集的Android 各类功能源代码

  • 16692/5   新一代Android渠道打包工具:1000个渠道包只需要5秒

  • 16619/21   Android福利第三波【Android电子书】

  • 16438/53   基于瀑布流的美女图片浏览App,有注释的源代码

  • 16419/81   【精品推荐】类似360安全卫士安Android源码:非常赞的产品原型

  • 16406/10   女程序员的梦,众网友的神回复

  • 16367/0   iOS中文版资源库,非常全

  • 16342/17   用JavaScript 来开发iOS和Android 原生应用:React Native开源框架中文版来啦

  • 16096/11   年会上现场review代码是怎么样的体验!

  • 16042/23   珍藏多年的素材,灵感搜寻网站

  • 15525/18   65条最常用正则表达式,你要的都在这里了

  • 14853/15   基于Android支付宝支付设计和开发方案

  • 14259/11   有木有这样一张酷图帮你集齐所有git命令超实用

  • 14190/17   什么是真正的黑客:收获12200+Stars,人气远超微软开源VS

  • 13970/46   在线音乐播放器完整版(商用级的源码):非常赞,可听免费高品质专辑

  • 13719/0   GitHub iOS 库和框架Top100 

  • 13675/61   【技巧一】搭配Android Studio,如何实现App远程真机debug?

  • 13570/7   用程序员的姿势抢过年的火车票

  • 13523/7   一张图搞定iOS学习路线,非常全面

  • 13152/10   成为Java顶尖程序员 ,看这11本书就够了

  • 13110/10   微信支付终于成功了(安卓,iOS),在此分享

  • 12999/18   一张图搞定Android学习路线,非常全面

  • 12811/29   【持续更新中】Android福利贴(一):资料源码

  • 12747/3   基于Node.js的强大爬虫,能直接发布抓取的文章哦

  • 12491/4   46 个非常有用的 PHP 代码片段

  • 12014/3   即时通信第三方库

  • 11452/8   流媒体视频直播方案

  • 11385/18   八个最优秀的Android Studio插件

  • 11256/9   B站建开源工作组:APP想支持炫酷弹幕的看过来

  • 11048/9   烧了5亿美金,这家神秘的公司即将颠覆人类未来!

  • 11033/2   【精品推荐】高质量PHP代码的50个实用技巧:非常值得收藏

  • 10952/10   中国黑客的隐秘江湖:攻守对立,顶尖高手月入千万美元

  • 10228/6   开箱即用!Android四款系统架构工具

  • 10017/10   十大技巧快速提升Android应用开发性能

  • 9975/3   10款GitHub上最火爆的国产开源项目——可以媲美西半球

  • 9922/1   Android性能优化视频,文档以及工具

  • 9810/0   基于node-webkit跨平台应用案例集之(一)

  • 返回顶部