如何避免KeyDispatchTimeout
1:UI线程尽量只做跟UI相关的工作
2:耗时的工作(比如数据库操作,I/O,连接网络或者别的有可能阻碍UI线程的操作)把它放入单独的线程处理
3:尽量用Handler来处理UIthread和别的thread之间的交互

如何去分析ANR

DALVIK THREADS (22):
"main" prio=5 tid=1 Native| group="main" sCount=1 dsCount=0 obj=0x74729000 self=0xf4827800| sysTid=29242 nice=0 cgrp=default sched=0/0 handle=0xf7779bec| state=D schedstat=( 1168866313 28837852 971 ) utm=90 stm=26 core=5 HZ=100| stack=0xff5f3000-0xff5f5000 stackSize=8MB| held mutexes=kernel: (couldn't read /proc/self/task/29242/stack)native: (backtrace::Unwind failed for thread 29242)at libcore.io.Posix.fsync(Native method)at libcore.io.BlockGuardOs.fsync(BlockGuardOs.java:143)at java.io.FileDescriptor.sync(FileDescriptor.java:74)at android.os.FileUtils.sync(FileUtils.java:152)at android.app.SharedPreferencesImpl.writeToFile(SharedPreferencesImpl.java:598)at android.app.SharedPreferencesImpl.access$800(SharedPreferencesImpl.java:51)at android.app.SharedPreferencesImpl$2.run(SharedPreferencesImpl.java:512)- locked <@addr=0x32c014d0> (a java.lang.Object)at android.app.SharedPreferencesImpl.enqueueDiskWrite(SharedPreferencesImpl.java:533)at android.app.SharedPreferencesImpl.access$100(SharedPreferencesImpl.java:51)at android.app.SharedPreferencesImpl$EditorImpl.commit(SharedPreferencesImpl.java:455)at com.zhangyue.iReader.DB.SPHelper.setString(SourceFile:56)- locked <@addr=0x32c01810> (a com.zhangyue.iReader.DB.SPHelper)at com.zhangyue.iReader.account.a.a(SourceFile:533)at com.zhangyue.iReader.account.a.b(SourceFile:526)at com.zhangyue.iReader.account.a.a(SourceFile:215)at com.zhangyue.iReader.app.APP.initAPP(SourceFile:681)at com.zhangyue.iReader.app.APP.initAPPData(SourceFile:731)at com.zhangyue.iReader.app.IreaderApplication.onCreate(SourceFile:53)at com.ireader.plug.utils.a.a(unavailable:-1)at com.ireader.plug.api.IreaderPlugApi.initPlugin(unavailable:-1)at com.android.browser.Browser.onCreate(SourceFile:77)at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1024)at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5084)at android.app.ActivityThread.access$1600(ActivityThread.java:187)at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1646)at android.os.Handler.dispatchMessage(Handler.java:111)at android.os.Looper.loop(Looper.java:194)at android.app.ActivityThread.main(ActivityThread.java:5871)at java.lang.reflect.Method.invoke!(Native method)at java.lang.reflect.Method.invoke(Method.java:372)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1119)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:885)"Heap thread pool worker thread 0" prio=5 tid=2 Native (still starting up)| group="" sCount=1 dsCount=0 obj=0x0 self=0xeec4d400| sysTid=29250 nice=0 cgrp=default sched=0/0 handle=0xf5078000| state=S schedstat=( 616307 0 18 ) utm=0 stm=0 core=7 HZ=100| stack=0xf4390000-0xf4392000 stackSize=1020KB| held mutexes=kernel: (couldn't read /proc/self/task/29250/stack)native: #00 pc 000134a4  /system/lib/libc.so (syscall+28)native: #01 pc 000a9b27  /system/lib/libart.so (art::ConditionVariable::Wait(art::Thread*)+74)native: #02 pc 00237b0f  /system/lib/libart.so (art::ThreadPool::GetTask(art::Thread*)+50)native: #03 pc 00237ab9  /system/lib/libart.so (art::ThreadPoolWorker::Run()+52)native: #04 pc 002382e1  /system/lib/libart.so (art::ThreadPoolWorker::Callback(void*)+52)native: #05 pc 00016f97  /system/lib/libc.so (__pthread_start(void*)+30)native: #06 pc 00014f9f  /system/lib/libc.so (__start_thread+6)(no managed stack frames)

拿到一个日志文件,要分成多段来看 。 log文件很长,其中包含十几个小单元信息,但不要被吓到 ,事实上他主要由三大块儿组成 。

1,系统基本信息 ,包括 内存,CPU ,进程队列 ,虚拟内存 , 垃圾回收等信息 。------ MEMORY INFO (/proc/meminfo) ------
------ CPU INFO (top -n 1 -d 1 -m 30 -t) ------
------ PROCRANK (procrank) ------
------ VIRTUAL MEMORY STATS (/proc/vmstat) ------
------ VMALLOC INFO (/proc/vmallocinfo) ------

格式如下:
------ MEMORY INFO (/proc/meminfo) ------
MemTotal: 347076 kB
MemFree: 56408 kB
Buffers: 7192 kB
Cached: 104064 kB
SwapCached: 0 kB
Active: 192592 kB
Inactive: 40548 kB
Active(anon): 129040 kB
Inactive(anon): 1104 kB
Active(file): 63552 kB
Inactive(file): 39444 kB
Unevictable: 7112 kB
Mlocked: 0 kB
SwapTotal: 0 kB
SwapFree: 0 kB
Dirty: 44 kB
Writeback: 0 kB
AnonPages: 129028 kB
Mapped: 73728 kB
Shmem: 1148 kB
Slab: 13072 kB
SReclaimable: 4564 kB
SUnreclaim: 8508 kB
KernelStack: 3472 kB
PageTables: 12172 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 173536 kB
Committed_AS: 7394524 kB
VmallocTotal: 319488 kB
VmallocUsed: 90752 kB
VmallocChunk: 181252 kB

2,时间信息 , 也是我们主要分析的信息 。
------ VMALLOC INFO (/proc/vmallocinfo) ------
------ EVENT INFO (/proc/vmallocinfo) ------

格式如下:
------ SYSTEM LOG (logcat -b system -v time -d *:v) ------
01-15 16:41:43.671 W/PackageManager( 2466): Unknown permission com.wsomacp.permission.PROVIDER in package com.android.mms
01-15 16:41:43.671 I/ActivityManager( 2466): Force stopping package com.android.mms uid=10092
01-15 16:41:43.675 I/UsageStats( 2466): Something wrong here, didn’t expect com.sec.android.app.twlauncher to be paused
01-15 16:41:44.108 I/ActivityManager( 2466): Start proc com.sec.android.widgetapp.infoalarm for service com.sec.android.widgetapp.infoalarm/.engine.DataService: pid=20634 uid=10005 gids={3003, 1015, 3002}
01-15 16:41:44.175 W/ActivityManager( 2466): Activity pause timeout for HistoryRecord{48589868 com.sec.android.app.twlauncher/.Launcher}
01-15 16:41:50.864 I/KeyInputQueue( 2466): Input event
01-15 16:41:50.866 D/KeyInputQueue( 2466): screenCaptureKeyFlag setting 0
01-15 16:41:50.882 I/PowerManagerService( 2466): Ulight 0->7|0
01-15 16:41:50.882 I/PowerManagerService( 2466): Setting target 2: cur=0.0 target=70 delta=4.6666665 nominalCurrentValue=0
01-15 16:41:50.882 I/PowerManagerService( 2466): Scheduling light animator!
01-15 16:41:51.706 D/PowerManagerService( 2466): enableLightSensor true
01-15 16:41:51.929 I/KeyInputQueue( 2466): Input event
01-15 16:41:51.933 W/WindowManager( 2466): No focus window, dropping: KeyEvent{action=0 code=26 repeat=0 meta=0 scancode=26 mFlags=9}

3,虚拟机信息 , 包括进程的,线程的跟踪信息,这是用来跟踪进程和线程具体点的好地方 。
------ VM TRACES JUST NOW (/data/anr/traces.txt.bugreport: 2011-01-15 16:49:02) ------
------ VM TRACES AT LAST ANR (/data/anr/traces.txt: 2011-01-15 16:49:02) ------

格式如下 :
----- pid 21161 at 2011-01-15 16:49:01 -----
Cmd line: com.android.mmsDALVIK THREADS:
"main" prio=5 tid=1 NATIVE| group="main" sCount=1 dsCount=0 s=N obj=0x4001d8d0 self=0xccc8| sysTid=21161 nice=0 sched=0/0 cgrp=default handle=-1345017808| schedstat=( 4151552996 5342265329 10995 )at android.media.MediaPlayer._reset(Native Method)at android.media.MediaPlayer.reset(MediaPlayer.java:1218)at android.widget.VideoView.release(VideoView.java:499)at android.widget.VideoView.access$2100(VideoView.java:50)at android.widget.VideoView$6.surfaceDestroyed(VideoView.java:489)at android.view.SurfaceView.reportSurfaceDestroyed(SurfaceView.java:572)at android.view.SurfaceView.updateWindow(SurfaceView.java:476)at android.view.SurfaceView.onWindowVisibilityChanged(SurfaceView.java:206)at android.view.View.dispatchDetachedFromWindow(View.java:6082)at android.view.ViewGroup.dispatchDetachedFromWindow(ViewGroup.java:1156)at android.view.ViewGroup.removeAllViewsInLayout(ViewGroup.java:2296)at android.view.ViewGroup.removeAllViews(ViewGroup.java:2254)at com.android.mms.ui.SlideView.reset(SlideView.java:687)at com.android.mms.ui.SlideshowPresenter.presentSlide(SlideshowPresenter.java:189)at com.android.mms.ui.SlideshowPresenter$3.run(SlideshowPresenter.java:531)at android.os.Handler.handleCallback(Handler.java:587)at android.os.Handler.dispatchMessage(Handler.java:92)at android.os.Looper.loop(Looper.java:123)at android.app.ActivityThread.main(ActivityThread.java:4627)at java.lang.reflect.Method.invokeNative(Native Method)at java.lang.reflect.Method.invoke(Method.java:521)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)at dalvik.system.NativeStart.main(Native Method)

我总结了观察log文件的基本步骤 。
1,如果是ANR问题 , 则搜索“ANR ”关键词 。 快速定位到关键事件信息 。
2,如果是ForceClosed 和其它异常退出信息,则搜索"Fatal" 关键词, 快速定位到关键事件信息 。如果是crash,则搜索CRASH.
3,定位到关键事件信息后 , 如果信息不够明确的,再去搜索应用程序包的虚拟机信息 ,查看具体的进程和线程跟踪的日志,来定位到代码 。 搜索 DALVIK THREADS ,查看tid=1的进程的情况
4, 搜索你的包名,进程名等。

用这种方法,出现问题,根本不需要断点调试 , 直接定位到问题,屡试不爽 。
下面,我们就开始来分析这个例子的log 。

打开log文件 , 由于是ANR错误,因此搜索"ANR " , 为何要加空格呢,你加上和去掉比较一下就知道了 。 可以屏蔽掉不少保存到anr.log文件的无效信息 。

参考:http://blog.csdn.net/dadoneo/article/details/8270107

Android ANR详解相关推荐

  1. Android App优化之ANR详解

    引言 背景:Android App优化, 要怎么做? Android App优化之性能分析工具 Android App优化之提升你的App启动速度之理论基础 Android App优化之提升你的App ...

  2. 【转】Android菜单详解——理解android中的Menu--不错

    原文网址:http://www.cnblogs.com/qingblog/archive/2012/06/08/2541709.html 前言 今天看了pro android 3中menu这一章,对A ...

  3. Android菜单详解——理解android中的Menu

    前言 今天看了pro android 3中menu这一章,对Android的整个menu体系有了进一步的了解,故整理下笔记与大家分享. PS:强烈推荐<Pro Android 3>,是我至 ...

  4. Android LayoutInflater详解

    Android LayoutInflater详解 在实际开发中LayoutInflater这个类还是非常有用的,它的作用类 似于findViewById().不同点是LayoutInflater是用来 ...

  5. android Fragments详解

    android Fragments详解一:概述 android Fragments详解二:创建Fragment 转载于:https://my.oschina.net/liangzhenghui/blo ...

  6. android WebView详解,常见漏洞详解和安全源码(下)

    上篇博客主要分析了 WebView 的详细使用,这篇来分析 WebView 的常见漏洞和使用的坑.  上篇:android WebView详解,常见漏洞详解和安全源码(上)  转载请注明出处:http ...

  7. android WebView详解,常见漏洞详解和安全源码(上)

    这篇博客主要来介绍 WebView 的相关使用方法,常见的几个漏洞,开发中可能遇到的坑和最后解决相应漏洞的源码,以及针对该源码的解析.  由于博客内容长度,这次将分为上下两篇,上篇详解 WebView ...

  8. android子视图无菜单,Android 菜单详解

    Android中菜单分为三种,选项菜单(OptionMenu),上下文菜单(ContextMenu),子菜单(SubMenu) 选项菜单 可以通过两种办法增加选项菜单,一是在menu.xml中添加,该 ...

  9. Android StateFlow详解

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/121913352 本文出自[赵彦军的博客] 文章目录 系列文章 一.冷流还是热流 S ...

最新文章

  1. GitHub 热榜:来膜拜这个流弊的 AI 框架!
  2. linux安装中文环境,[Linux]Ubuntu 7.04 中文环境的安装
  3. Symbian,倒在3G的门槛上
  4. 浅谈a标签属性href的mailto更多用法
  5. 窗体控件绑定数组 c# 1613698204
  6. [转]双线性插值(Bilinear interpolation)
  7. win10配置内外网同时使用
  8. vmware虚拟机设置静态ip地址
  9. 【经验贴】Java搭建一个以yy直播为主的直播聊天室
  10. php转调页面,如何转调
  11. 用anaconda启动Spyder报错
  12. vue3中的tsx写法
  13. 地理商业智能发展浅析
  14. 只会教学育人,清华解聘50岁副教授
  15. 1056: 幸运数字 Python
  16. 逻辑运算符与或非(基础学习)
  17. 白天看投影仪哪个牌子最好?家用投影仪推荐一下哪款比较好
  18. java导出word实现方式一,在jsp中实现
  19. Docker 创建 Bamboo6.7.1 以及与 Crowd3.3.2 实现 SSO 单点登录
  20. C语言 求一元二次方程ax2+bx+c=0的根

热门文章

  1. java script 月日年转年月日_js的如何进行日期格式转换成年月日
  2. AR+ 实时音视频通话,×××无缝结合
  3. SylixOS DSP upgrade命令解析
  4. [Dynamic Language] Python3.7 源码安装 ModuleNotFoundError: No module named '_ctypes' 解决记录...
  5. 怎样做到真实再现传统文化艺术?
  6. 微信小程序开发踩坑日记
  7. lt;ASP.NET4 从入门到精通gt;学习笔记3
  8. 剑指offer系列之十:二进制中1的个数
  9. modify timezone
  10. [zz] 深入java虚拟机之本地方法