转载android常见错误。

一般在平时工作中,基本上很多代码可以在eclipse+ndk进行调试,但如果需要用到具体的硬件设备,如媒体播放设备无法模拟的情况下,只能上硬件(盒子或手机)上进行调试。此时唯一的调试手段就是logcat产生log信息进行分析问题了。

  什么时候会有Log文件的产生 ?一般在如下几种情况会产生log文件 。

  1、程序异常退出 uncaused exception

  2、程序强制关闭 Force Closed (简称FC)

  3、程序无响应 Application No Response(简称ANR),一般主线程超过5秒么有处理就会ANR

  4、手动生成

  进入控制台输入:logcat命令即可进行输出

  第一部分

  1、分析工具介绍

  a、cat /proc/meminfo 显示基本的内存信息

  ------ MEMORY INFO (/proc/meminfo) ------

  MemTotal: 285184 kB

  MemFree: 106360 kB

  Buffers: 0 kB

  Cached: 60036 kB

  SwapCached: 0 kB

  Active: 98160 kB

  Inactive: 49100 kB

  Active(anon): 87260 kB

  Inactive(anon): 288 kB

  Active(file): 10900 kB

  Inactive(file): 48812 kB

  Unevictable: 0 kB

  Mlocked: 0 kB

  SwapTotal: 0 kB

  SwapFree: 0 kB

  Dirty: 0 kB

  Writeback: 0 kB

  AnonPages: 87240 kB

  Mapped: 26500 kB

  Shmem: 324 kB

  Slab: 13340 kB

  SReclaimable: 1672 kB

  SUnreclaim: 11668 kB

  KernelStack: 2160 kB

  PageTables: 5600 kB

  NFS_Unstable: 0 kB

  Bounce: 0 kB

  WritebackTmp: 0 kB

  CommitLimit: 142592 kB

  Committed_AS: 1065600 kB

  VmallocTotal: 417792 kB

  VmallocUsed: 137700 kB

  VmallocChunk: 254980 kB

  重点关注这下面几个值:

  MemTotal: 285184 kB //总计物理内存的大小

  MemFree: 106360 kB //可用内存有多少

  Buffers: 0 kB //磁盘缓存内存的大小

  Cached: 60036 kB

  # free

  free

  total used free shared buffers

  Mem: 285184 178884 106300 0 0

  Swap: 0 0 0

  Total: 285184 178884 106300

  在linux中有这么一种思想,内存不用白不用,因此它尽可能的cache和buffer一些数据,以方便下次使用。

  但实际上这些内存也是可以立刻拿来使用的。

  所以空闲内存=free+buffers+cached=total-used

  还有几个命令可使用:

  /proc/meminfo 机器的内存使用信息

  /proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址。

  /proc/pid/statm 进程所占用的内存

  b、查看进程信息

  ------ CPU INFO (top -n 1 -d 1 -m 30 -t) ------

  能够实时显示系统中各个进程的资源占用状况,类似于 Windows 的任务管理器

  c、android提供的一些操作工具

  ------ PROCRANK (procrank) ------

  ------ PROCMEM (procmem) ------

  ------ SHOWMAP (showmap) ------

  ... 就不一一列举了,有兴趣的朋友可以去看看

  这此工具的代码位于android的 /system/extras

  d、虚拟内存的查看工具

  ------ VIRTUAL MEMORY STATS (/proc/vmstat) ------

  ------ VMALLOC INFO (/proc/vmallocinfo) ------

  2、时间信息,也是我们主要分析的信息

  格式如下:

  ------ SYSTEM LOG (logcat -b system -v time -d *:v) ------

  $:logcat -b system -v time -d *:v

  01-02 08:00:02.570 I/SystemServer( 957): Notification Manager

  01-02 08:00:02.570 I/SystemServer( 957): Device Storage Monitor

  01-02 08:00:02.580 I/SystemServer( 957): Location Manager

  01-02 08:00:02.580 I/SystemServer( 957): Search Service

  01-02 08:00:02.590 I/SystemServer( 957): DropBox Service

  01-02 08:00:02.590 I/SystemServer( 957): Wallpaper Service

  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 1516 at 1970-01-02 08:03:07 -----

  Cmd line: com.ipanel.join.appstore

  DALVIK THREADS:

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

  "main" prio=5 tid=1 NATIVE

  | group="main" sCount=1 dsCount=0 obj=0x4001f188 self=0xd028

  | sysTid=1516 nice=0 sched=3/0 cgrp=[fopen-error:2] handle=-1345017744

  第二部分

  如何分析log信息

  1、查找错误信息的关键字眼

  "error" "failxx" "E/" 等的错误信息

  将这些问题先行解决掉

  2、动态库死机

  查看类似的“Build fingerprint:”这些关键字

  I/DEBUG ( 692): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***

  I/DEBUG ( 692): Build fingerprint: 'generic/generic/generic:2.3.1/GRH78/eng.userdev-rd6-input.20120221.113348:eng/test-keys'

  I/DEBUG ( 692): pid: 694, tid: 694 >>> /system/bin/mediaserver <<<

  I/DEBUG ( 692): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000input module init -->

  010

  对于这此信息,可以查看动态库的分析:

  http://blog.csdn.net/andyhuabing/article/details/7074979

  3、解决java抛异常的问题解决

  E/UsbObserver( 957): java.lang.NullPointerException

  E/UsbObserver( 957): at com.android.server.UsbObserver.init(UsbObserver.java:131)

  E/UsbObserver( 957): at com.android.server.UsbObserver.<init>(UsbObserver.java:65)

  E/UsbObserver( 957): at com.android.server.ServerThread.run(SystemServer.java:419)

  I/SystemServer( 957): UI Mode Manager Service

  这个直接找到java代码,分析其实现即可解决

  4、ANR问题

  搜索“ANR”关键词,快速定位到关键事件信息 。

  定位到关键的事件信息如下:

  I/dalvikvm( 1014): Wrote stack traces to '/data/anr/traces.txt'

  I/Process ( 957): Sending signal. PID: 1124 SIG: 9

  E/ActivityManager( 957): ANR in com.ipanel.join.appstore

  E/ActivityManager( 957): Reason: Broadcast of Intent { act=android.appwidget.action.APPWIDGET_UPDATE cmp=com.ipanel.join.appstore/.widget.SmallWidget1 (has extras) }

  E/ActivityManager( 957): Load: 1.57 / 0.38 / 0.13

  E/ActivityManager( 957): CPU usage from 6290ms to 0ms ago:

  E/ActivityManager( 957): 70% 957/system_server: 1.1% user + 69% kernel / faults: 204 minor

  E/ActivityManager( 957): 8.7% 1014/com.ipanel.join.home.jelly: 7.7% user + 0.9% kernel / faults: 899 minor

  E/ActivityManager( 957): 0.3% 687/yaffs-bg-1: 0% user + 0.3% kernel

  E/ActivityManager( 957): 0.3% 688/yaffs-bg-1: 0% user + 0.3% kernel

  E/ActivityManager( 957): 0.3% 935/irkeyservice: 0% user + 0.3% kernel

  E/ActivityManager( 957): 0% 890/galcore daemon : 0% user + 0% kernel

  E/ActivityManager( 957): 0.1% 1076/com.ipanel.join.browser: 0.1% user + 0% kernel

  E/ActivityManager( 957): 0.1% 1124/com.ipanel.join.appstore: 0.1% user + 0% kernel

  E/ActivityManager( 957): 75% TOTAL: 4.7% user + 70% kernel

  E/ActivityManager( 957): CPU usage from 622ms to 1169ms later:

  E/ActivityManager( 957): 71% 957/system_server: 0% user + 71% kernel / faults: 2 minor

  E/ActivityManager( 957): 67% 965/SurfaceFlinger: 0% user + 67% kernel

  E/ActivityManager( 957): 1.9% 973/ActivityManager: 1.9% user + 0% kernel

  E/ActivityManager( 957): 1.9% 991/CursorMove: 0% user + 1.9% kernel

  E/ActivityManager( 957): 7.6% 1014/com.ipanel.join.home.jelly: 7.6% user + 0% kernel / faults: 31 minor

  E/ActivityManager( 957): 5.7% 1119/Thread-13: 5.7% user + 0% kernel

  E/ActivityManager( 957): 1.9% 1123/Thread-13: 1.9% user + 0% kernel

  E/ActivityManager( 957): 76% TOTAL: 1.8% user + 72% kernel + 1.8% softirq

  指定哪个java包出问题

  E/ActivityManager( 957): ANR in com.ipanel.join.appstore

  进程号为957发生了如下错误:com.ipanel.join.appstore 包下面 Broadcast问题

  ANR原因:

  E/ActivityManager( 957): Reason: Broadcast of Intent { act=android.appwidget.action.APPWIDGET_UPDATE cmp=com.ipanel.join.appstore/.widget.SmallWidget1 (has extras) }

  这是ANR的堆栈调用文件

  I/dalvikvm( 1014): Wrote stack traces to '/data/anr/traces.txt'

  通过上面的log信息分析,应该是接收一个广播消息时超时了

  我们再分析虚拟机信息 ,打开/data/anr/traces.txt,可有通过adb pull /data/anr/traces.txt .

  这里每一段都是一个线程 ,当然我们还是看线程号为1的主线程了。通过分析发现关键问题是这样:

  搜索“DALVIK THREADS”关键词,快速定位到本应用程序的虚拟机信息日志

  ----- pid 1516 at 1970-01-02 08:03:07 -----

  Cmd line: com.ipanel.join.appstore

  DALVIK THREADS:

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

  "main" prio=5 tid=1 NATIVE

  | group="main" sCount=1 dsCount=0 obj=0x4001f188 self=0xd028

  | sysTid=1516 nice=0 sched=3/0 cgrp=[fopen-error:2] handle=-1345017744

  at org.apache.harmony.luni.platform.OSNetworkSystem.connect(Native Method)

  at dalvik.system.BlockGuard$WrappedNetworkSystem.connect(BlockGuard.java:357)

  at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:204)

  at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:437)

  at java.net.Socket.connect(Socket.java:983)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection.<init>(HttpConnection.java:74)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection.<init>(HttpConnection.java:48)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection$Address.connect(HttpConnection.java:298)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnectionPool.get(HttpConnectionPool.java:89)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getHttpConnection(HttpURLConnectionImpl.java:285)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.makeConnection(HttpURLConnectionImpl.java:267)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.retrieveResponse(HttpURLConnectionImpl.java:1018)

  at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:726)

  at com.ipanel.join.appstore.http.DefaultHttpRequest.doGet(DefaultHttpRequest.java:35)

  at com.ipanel.join.appstore.widget.AbsSmallWidget.requestApps(AbsSmallWidget.java:117)

  at com.ipanel.join.appstore.widget.AbsSmallWidget.getRemoteViews(AbsSmallWidget.java:56)

  其实从这句话:

  at org.apache.harmony.luni.platform.OSNetworkSystem.connect(Native Method)

  基本上确认是 socket ->connect 连接超时了,导致主线程5s内没有响应从而产生ANR错误。默认的connect连接timeout时间是75s

  其实解决办法就是利用非阻塞方式进行连接即可。

  从CPU占用率上也可以看出是在kernel中执行堵塞住了

  E/ActivityManager( 957): 75% TOTAL: 4.7% user + 70% kernel

  5、执行DexOpt错误

  W/dalvikvm( 1803): DexOpt: --- END 'SettingsProvider.apk' --- status=0x000a, process failed

  E/dalvikvm( 1803): Unable to extract+optimize DEX from '/system/app/SettingsProvider.apk'

  E/SystemServer( 1803): Failure starting Input Manager Service

  E/SystemServer( 1803): java.lang.RuntimeException: Unable to get provider com.android.providers.settings.SettingsProvider: java.lang.ClassNotFoundException: com.android.providers.settings.SettingsProvider in loader dalvik.system.PathClassLoader[/system/app/SettingsProvider.apk]

  E/SystemServer( 1803): at android.app.ActivityThread.installProvider(ActivityThread.java:3557)

  E/SystemServer( 1803): at android.app.ActivityThread.getProvider(ActivityThread.java:3356)

  从上面的打印看,是在解压或优化extract+optimize DEX的apk文件时出错了

  1、没有出现magic number错误,这个原因与原子操作无关(这是一快速的加锁和解锁的轻量级操作函数)

  2、执行dexopt出错

  查明是服务器硬盘没空间了,导致引导文件系统的时候没有空间进行解压而失败

  6、系统启动后默认其妙或随机死机情况

  出现这种错误:

  12-01 08:11:56.027: WARN/SharedBufferStack(312): waitForCondition(LockCondition) timed out (identity=19, status=0). CPU may be pegged. trying again.

  12-01 08:11:57.315: WARN/SharedBufferStack(312): waitForCondition(LockCondition) timed out (identity=19, status=0). CPU may be pegged. trying again.

  12-01 08:11:59.318: WARN/SharedBufferStack(312): waitForCondition(LockCondition) timed out (identity=19, status=0). CPU may be pegged. trying again.

  12-01 08:12:03.332: WARN/SharedBufferStack(312): waitForCondition(LockCondition) timed out (identity=19, status=0). CPU may be pegged. trying again.

  12-01 08:12:05.329: WARN/SharedBufferStack(312): waitForCondition(LockCondition) timed out (identity=19, status=0). CPU may be pegged. trying again.

  12-01 08:12:07.216: WARN/KeyCharacterMap(312): No keyboard for id 0

  12-01 08:12:07.216: WARN/KeyCharacterMap(312): Using default keymap: /system/usr/keychars/qwerty.kcm.bin

  查看内存: cat /proc/meminfo 发现空闲内存只剩下几M空间了。

  请加大android系统的内存即可解决问题


原文见:

http://android.tgbus.com/Android/androidnews/201205/428729.shtml

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. Gradle同步失败:这可能是由于Gradle版本不兼容或网络连接问题引起的。可以尝试更改Gradle版本或检查网络连接。 2. 编译错误:这可能是由于代码错误、缺少依赖项或版本不兼容引起的。可以尝试修复代码错误、添加缺少的依赖项或更改版本。 3. 设备连接问题:这可能是由于设备驱动程序问题、USB连接问题或设备未启用调试模式引起的。可以尝试更新设备驱动程序、更换USB线或启用调试模式。 4. Emulator启动问题:这可能是由于Emulator配置错误、缺少系统镜像或硬件要求不满足引起的。可以尝试更改Emulator配置、下载所需的系统镜像或升级计算机硬件。 5. 插件问题:这可能是由于插件版本不兼容或插件未正确安装引起的。可以尝试更新插件版本或重新安装插件。 6. 资源文件问题:这可能是由于资源文件缺失、命名错误或格式不正确引起的。可以尝试添加缺失的资源文件、更正命名错误或更改格式。 7. Android SDK问题:这可能是由于Android SDK未正确安装或版本不兼容引起的。可以尝试重新安装Android SDK或更改版本。 8. 版本控制问题:这可能是由于版本控制冲突或错误引起的。可以尝试解决版本控制冲突或撤销错误提交。 9. 内存问题:这可能是由于内存不足或内存泄漏引起的。可以尝试优化代码、释放不必要的内存或增加计算机内存。 10. 其他问题:这可能是由于其他未知问题引起的。可以尝试查找错误日志或寻求帮助。 ### 回答2: Android Studio是一款非常流行的开发Android应用程序的集成开发环境,但是在使用中,会出现一些常见错误。下面我们将介绍一些常见错误和解决方案。 1. Gradle build错误: 这个错误通常表示您的构建脚本存在问题。要解决此问题,请检查gradle脚本是否有任何语法错误或逻辑错误,并且您的依赖项是否正确。 2. 资源未找到错误: 这个错误通常发生在您未正确引用资源文件。要解决此问题,请检查资源引用的文件名是否正确,以及是否正确引用资源的文件夹。 3. 编译错误: 这个错误通常发生在您的代码存在语法错误或逻辑错误。请检查您的代码是否正确,并且是否使用正确的Java语法。 4. 设备连接错误: 这个错误通常表示您的Android设备无法与Android Studio建立连接。要解决此问题,请检查您的连接是否正确,并检查您的设备是否启用了USB调试模式。 5. Emulator启动失败: 这个错误通常表示您的模拟器配置存在问题。要解决此问题,请检查您的模拟器配置是否正确,并确保您的计算机满足模拟器的要求。 6. 编译版本错误: 这个错误通常表示您的项目使用了错误的编译版本。要解决此问题,请确保您的编译版本正确,并重新构建您的项目。 总之,在使用Android Studio开发应用程序时,常见错误是无法避免的。但是,遵循最佳实践并遵循正确的开发流程可以减少这些错误的发生。在出现错误时,要保持冷静,并找到正确的解决方案以解决问题。 ### 回答3: Android Studio是开发Android应用程序时最流行的集成开发环境,但是使用它时还是会出现一些常见错误。本文将介绍一些Android Studio常见错误及其解决方案。 1. Gradle错误 Gradle是Android Studio使用的构建工具,它负责将Java代码编译成可执行的Apk文件。Gradle错误可能是由于网络连接问题造成,也可能是代码中存在错误。 解决方案:如果Gradle下载失败,则可以尝试手动下载Gradle文件并将其复制到Gradle目录中。如果Gradle构建过程中发生错误,则可以尝试清除Gradle缓存,重新构建项目或者检查项目中的代码错误。 2. Emulator错误 Android Studio自带模拟器(Emulator),但它不太流畅,并且需要大量的系统资源。如果模拟器出现了错误,可能会影响应用程序的开发和测试。 解决方案:使用其他第三方模拟器,例如Genymotion。如果计算机配置过低,可以尝试使用真实设备进行测试。 3. SDK路径错误 Android Studio需要指定Android SDK的路径。如果SDK路径错误,则可能导致应用程序无法正常构建和运行。 解决方案:在Android Studio中打开SDK管理器,检查SDK路径是否正确。如果SDK路径错误,则可以手动更改路径并重新启动Android Studio。 4. 版本兼容问题 Android应用程序的版本兼容问题可能会导致一些错误,例如在运行时出现异常或应用程序在某些设备上无法运行。 解决方案:检查应用程序在不同版本的Android系统上的兼容性,使用最新的Android SDK版本和Android API,并在应用程序中使用适当的兼容性库。 5. Android Studio崩溃 Android Studio可能会崩溃并导致应用程序无法运行。这可能是因为缺少系统资源或由于Android Studio本身的错误。 解决方案:尝试关闭Android Studio并重新打开它。如果问题依然存在,则可以尝试重新安装Android Studio或更新到最新版本。 总之,在使用Android Studio时,经常会遇到各种各样的错误,但这不是问题,所有的错误都是可以解决的。要想有效的解决错误,需要仔细阅读错误信息,并仔细调试问题。只要专注和耐心,相信你可以轻松解决Android Studio的所有常见错误

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值