手机ANR问题处理方法及策略


APR问题一般分为以下几类,ANRCrashTomstoneNE)、KEANR即为应用无响应,Crash为应用崩溃,可能是空指针、安全、权限、内存泄露等原因造成;Tomstonenative层异常引起,可能为内存引用错误、空指针等造成;KEkernel  exception,即内核异常造成,作为上层开发人员,遇到KE,可以转给驱动分析或者提给MTK分析。

1.ANR问题分析解决

1.1 什么是ANR

ANR:Application Not Responding,即应用无响应

1.2 ANR的类型

ANR一般有三种类型:

  1. KeyDispatchTimeout(5 seconds) --主要类型

按键或触摸事件在特定时间内无响应

(2) BroadcastTimeout(10 seconds)   BroadcastReceiver在特定时间内无法处理完成

(3) ServiceTimeout(20 seconds) --小概率类型Service在特定的时间内无法处理完成

1.3 KeyDispatchTimeout

Akey or touch event was not dispatched within the specified time(按键或触摸事件在特定时间内无响应)

具体的超时时间的定义在framework下的

ActivityManagerService.java

//How long we wait until we timeout on key dispatching.

staticfinal int KEY_DISPATCHING_TIMEOUT = 5*1000

1.4为什么会超时呢?

超时时间的计数一般是从按键分发给app开始。超时的原因一般有两种:

(1) 当前的事件没有机会得到处理(即UI线程正在处理前一个事件,没有及时的完成或者looper被某种原因阻塞住了)。

(2) 当前的事件正在处理,但没有及时完成

1.5如何避免KeyDispatchTimeout

(1)  UI线程尽量只做跟UI相关的工作

(2) 耗时的工作(比如数据库操作,I/O,连接网络或者别的有可能阻碍UI线程的操作)把它放入单独的线程处理

(3) 尽量用Handler来处理UIthread和别的thread之间的交互

1.6 UI线程

说了那么多的UI线程,那么哪些属于UI线程呢?

UI线程主要包括如下:

 ```   Activity:onCreate(), onResume(), onDestroy(), onKeyDown(), onClick(),etc

    AsyncTask: onPreExecute(), onProgressUpdate(), onPostExecute(), onCancel,etc

    Mainthread handler: handleMessage(), post*(runnable r), etc

    other

1.7 如何去分析ANR

04-01 13:12:11.572 I/InputDispatcher( 220): Application is not responding:Window{2b263310com.android.email/com.android.email.activity.SplitScreenActivitypaused=false}.  5009.8ms since event, 5009.5ms since waitstarted

04-0113:12:11.572 I/WindowManager( 220): Input event dispatching timedout sending tocom.android.email/com.android.email.activity.SplitScreenActivity

04-01 13:12:14.123 I/Process(  220): Sending signal. PID: 21404 SIG: 3---发生ANR的时间和生成trace.txt的时间

04-01 13:12:14.123 I/dalvikvm(21404):threadid=4: reacting to signal 3

……

04-0113:12:15.872 E/ActivityManager(  220): ANR in com.android.email(com.android.email/.activity.SplitScreenActivity)

04-0113:12:15.872 E/ActivityManager(  220): Reason:keyDispatchingTimedOut

04-0113:12:15.872 E/ActivityManager(  220): Load: 8.68 / 8.37 / 8.53

04-0113:12:15.872 E/ActivityManager(  220): CPUusage from 4361ms to 699ms ago ----CPUANR发生前的使用情况

04-0113:12:15.872 E/ActivityManager(  220):   5.5%21404/com.android.email: 1.3% user + 4.1% kernel / faults: 10 minor

04-0113:12:15.872 E/ActivityManager(  220):   4.3%220/system_server: 2.7% user + 1.5% kernel / faults: 11 minor 2 major

04-0113:12:15.872 E/ActivityManager(  220):   0.9%52/spi_qsd.0: 0% user + 0.9% kernel

04-0113:12:15.872 E/ActivityManager(  220):   0.5%65/irq/170-cyttsp-: 0% user + 0.5% kernel

04-0113:12:15.872 E/ActivityManager(  220):   0.5%296/com.android.systemui: 0.5% user + 0% kernel

04-0113:12:15.872 E/ActivityManager(  220): 100%TOTAL: 4.8% user + 7.6% kernel + 87% iowait

04-0113:12:15.872 E/ActivityManager(  220): CPUusage from 3697ms to 4223ms later:-- ANRCPU的使用量

04-0113:12:15.872 E/ActivityManager(  220):   25%21404/com.android.email: 25% user + 0% kernel / faults: 191 minor

04-0113:12:15.872 E/ActivityManager(  220):    16% 21603/__eas(par.hakan: 16% user + 0% kernel

04-0113:12:15.872 E/ActivityManager(  220):    7.2% 21406/GC: 7.2% user + 0% kernel

04-0113:12:15.872 E/ActivityManager(  220):    1.8% 21409/Compiler: 1.8% user + 0% kernel

04-0113:12:15.872 E/ActivityManager(  220):   5.5%220/system_server: 0% user + 5.5% kernel / faults: 1 minor

04-0113:12:15.872 E/ActivityManager(  220):    5.5% 263/InputDispatcher: 0% user + 5.5% kernel

04-0113:12:15.872 E/ActivityManager(  220): 32%TOTAL: 28% user + 3.7% kernel

LOG可以看出ANR的类型,CPU的使用情况,如果CPU使用量接近100%,说明当前设备很忙,有可能是CPU饥饿导致了ANR

如果CPU使用量很少,说明主线程被BLOCK

如果IOwait很高,说明ANR有可能是主线程在进行I/O操作造成的

除了看LOG,解决ANR还得需要trace.txt文件,

如何获取呢?可以用如下命令获取

    $chmod 777 /data/anr

    $rm /data/anr/traces.txt

    $ps

    $kill -3 PID

    adbpull data/anr/traces.txt ./mytraces.txt

trace.txt文件,看到最多的是如下的信息:

-----pid 21404 at 2011-04-01 13:12:14 ----- 

Cmdline: com.android.email

DALVIK THREADS:

(mutexes: tll=0tsl=0 tscl=0 ghl=0 hwl=0 hwll=0)

"main" prio=5 tid=1NATIVE

  | group="main" sCount=1 dsCount=0obj=0x2aad2248 self=0xcf70

  | sysTid=21404 nice=0 sched=0/0cgrp=[fopen-error:2] handle=1876218976

  atandroid.os.MessageQueue.nativePollOnce(Native Method)

  atandroid.os.MessageQueue.next(MessageQueue.java:119)

  atandroid.os.Looper.loop(Looper.java:110)

 at android.app.ActivityThread.main(ActivityThread.java:3688)

 at java.lang.reflect.Method.invokeNative(Native Method)

  atjava.lang.reflect.Method.invoke(Method.java:507)

  atcom.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)

 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:624)

 at dalvik.system.NativeStart.main(Native Method)

说明主线程在等待下条消息进入消息队列

1.8  Thread状态

[java] view plaincopyprint?

    ThreadState (defined at “dalvik/vm/thread.h “) 

    THREAD_UNDEFINED = -1, /* makes enum compatible with int32_t */ 

    THREAD_ZOMBIE = 0, /* TERMINATED */ 

    THREAD_RUNNING = 1, /* RUNNABLE or running now */ 

    THREAD_TIMED_WAIT = 2, /* TIMED_WAITING in Object.wait() */ 

    THREAD_MONITOR = 3, /* BLOCKED on a monitor */ 

    THREAD_WAIT = 4, /* WAITING in Object.wait() */ 

    THREAD_INITIALIZING= 5, /* allocated, not yet running */ 

    THREAD_STARTING = 6, /* started, not yet on thread list */ 

    THREAD_NATIVE = 7, /* off in a JNI native method */ 

    THREAD_VMWAIT = 8, /* waiting on a VM resource */ 

    THREAD_SUSPENDED = 9, /* suspended, usually by GC or debugger */ 

1.9 如何调查并解决ANR

(1) 首先分析log

(2) trace.txt文件查看调用stack.

(3) 看代码

(4) 仔细查看ANR的成因(iowait?block?memoryleak?

1.10案例

案例1:关键词:ContentResolver in AsyncTask onPostExecute, high iowait

Process:com.android.email

Activity:com.android.email/.activity.MessageView

Subject:keyDispatchingTimedOut

CPU usage from 2550ms to -2814ms ago:

5%187/system_server: 3.5% user + 1.4% kernel / faults: 86 minor 20major

4.4% 1134/com.android.email: 0.7% user + 3.7% kernel /faults: 38 minor 19 major

4% 372/com.android.eventstream: 0.7%user + 3.3% kernel / faults: 6 minor

1.1% 272/com.android.phone:0.9% user + 0.1% kernel / faults: 33 minor

0.9%252/com.android.systemui: 0.9% user + 0% kernel

0%409/com.android.eventstream.telephonyplugin: 0% user + 0% kernel /faults: 2 minor

0.1% 632/com.android.devicemonitor: 0.1% user + 0%kernel

100%TOTAL: 6.9% user + 8.2% kernel +84%iowait

-----pid 1134 at 2010-12-17 17:46:51 -----

Cmd line:com.android.email

DALVIK THREADS:

(mutexes: tll=0 tsl=0tscl=0 ghl=0 hwl=0 hwll=0)

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值