APP测试要点

谁都会走 提交于 2020-03-10 18:30:25

 

 
 
    app出现ANR,是什么原因导致的?
    1.主线程执行了耗时操作,比如数据库操作或网络编程
    2.其他进程(就是其他程序)占用CPU导致本进程得不到CPU时间片,
      比如其他进程的频繁读写操作可能会导致这个问题。
 
    细分的话,导致ANR的原因有如下几点:
    1.耗时的网络访问
    2.大量的数据读写
    3.数据库操作
    4.硬件操作(比如camera)
    5.调用thread的join()方法、sleep()方法、wait()方法或者等待线程锁的时候
    6.service binder的数量达到上限
    7.system server中发生WatchDog ANR
    8.service忙导致超时无响应
    9.其他线程持有锁,导致主线程等待超时
    10.其它线程终止或崩溃导致主线程一直等待。
 
 
 
 
    App出现crash原因有哪些:
    1.内存管理错误:可能是可用内存过低,app所需的内存超过设备的限制,
      app跑不起来导致App crash。
      或是内存泄露,程序运行的时间越长,所占用的内存越大,最终用尽全部内存,导致整个系统崩溃。
      亦或非授权的内存位置的使用也可能会导致App crash。
    2.程序逻辑错误:数组越界、堆栈溢出、并发操作、逻辑错误:
        e.g. app新添加一个未经测试的新功能,调用了一个已释放的指针,运行的时候就会crash。
    3.设备兼容:由于设备多样性,app在不同的设备上可能会有不同的表现。
    4.网络因素:可能是网速欠佳,无法达到app所需的快速响应时间,导致app crash。
          或者是不同网络的切换也可能会影响app的稳定性。
 
 
 
 
 
    app对于不稳定偶然出现anr和crash时候你是怎么处理的?
    方法一:app开发保存错误日志到本地
           一般app开发在debug版本,出现anr和crash的时候会自动把日志保存到本地实际的sd卡上,
        去对应的app目录取出来就可以了
 
    方法二:实时抓取
           当出现偶然的crash时候,这时候可以把手机拉到你们app开发那,
           手机连上他的开发代码的环境,有ddms会抓日志,
               这时候出现crash就会记录下来日志。尽量重复操作让bug复现就可以了
 
 
    也可以自己开着logcat,保存日志到电脑本地
           命令:adb logcat | find "com.sankuai.meituan" >d:\hello.txt
 
 
 
 
 
 
 
 
 
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!