adb 命令抓取 error 级及以上 log :


adb logcat –v time –s AndroidRuntime:E   或


adb logcat –v time AndroidRuntime:E *:S


 


Log 信息级别


Log.v - VERBOSE  : 黑色


Log.d - DEBUG  : 蓝色


Log.i- INFO   : 绿色


Log.w- WARN   : 橙色


Log.e- ERROR   : 红色


 


优先级是下面的字符,顺序是从低到高:



V — 明细 verbose( 最低优先级 )



D — 调试 debug



I — 信息 info



W — 警告 warn



E — 错误 error



F — 严重错误 fatal



S — 无记载 silent



使用 logcat 命令查看 android 日志输出:


adb logcat     // 显示全部日志


adb logcat > c:\test.log // 将日志保存到文件 test.log


 


log 过滤 -


  l og 过滤器使用(   adb logcat tag:priprity )


过滤器表达式的格式是 tag:priority ... ,其中 tag 是标记(可以是具体的, * 表示所有), priority 是最小的优先级 , 可以是组合


adb logcat ActivityManager:I MyApp:D *:S


adb logcat * :W ----- 所有优先级大于等于 “warning” 的日志


adb logcat * :E ----- 所有优先级大于等于 “error” 的日志


仅输出标记为 “ActivityManager” 且优先级大于等于 “Info” 和标记为 “PowerManagerService” 并且优先级大于等于 “Debug” 的日志:


adb logcat ActivityManager:I PowerManagerService:D *:S


注: *:S 用于设置所有标记的日志优先级为 S ,这样可以确保仅输出符合条件的日志。


adb logcat *:W   // 显示所有优先级大于等于 “warning” 的日志


adb logcat -s PowerManagerService   // 显示 PowerManagerService 的日志信息


 


 


Logcat 命令列表: log 输出 -log 选项列表


-b <buffer> 指定要查看的日志缓冲区,可以是 system,events ,radio,main . 默认值是 system 和 main  。


-c  清楚屏幕上的日志 . 


-d  输出日志到屏幕上 . 


-f <filename> 指定输出日志信息的 <filename> ,默认是 stdout . 


-g  输出指定的日志缓冲区,输出后退出 . 


-n <count> 设置日志的最大数目 <count>. ,默认值是 4 ,需要和 -r 选项一起使用。  


-r <kbytes> 每 <kbytes> 时输出日志,默认值为 16 ,需要和 -f 选项一起使用 . 


-s  设置默认的过滤级别为 silent. 


-v <format> 设置日志输入格式


brief — 显示优先级 / 标记和原始进程的 PID ( 默认格式 )


process — 仅显示进程 PID


tag — 仅显示优先级 / 标记


thread — 仅显示进程:线程和优先级 / 标记


raw — 显示原始的日志信息,没有其他的元数据字段


time — 显示日期,调用时间,优先级 / 标记, PID


long — 显示所有的元数据字段并且用空行分隔消息内容


adb logcat -v thread   // 使用 thread 输出格式


注意 -v 选项中只能指定一种格式。


-b <buffer> 加载一个可使用的日志缓冲区供查看,默认值是 main 。



radio — 查看包含在无线 / 电话相关的缓冲区消息。( 通话、语音方面的 log, 抓跟网络之间的 ARM9 的 Log, 与 QXDM 的 Log 一般配套使用,所以通话类的问题必须使用 QXDM 抓取 Modem log 和 AP 侧 radio log )



events — 查看事件相关的消息。( 是基本操作类的 log 。比如:常见的一些错误都可以使用此来抓取 LOG )



main — 查看主缓冲区 ( 默认缓冲区 ) 。( 是基本操作类的 log 。比如:常见的一些错误都可以使用此来抓取 LOG )


adb logcat -b radio     // 查看 radio 缓冲区



MTK usr 和 eng 的区别


MTK  补充说明差异 :



(1) Debug/LOG  方面,原则上 user 版本只能抓到有限的资讯, eng 可以抓到更多的资讯, Debug 能力更强,推崇使用 eng 版本开发 测试



*        因 user/eng 版本设置 ro.secure 不同,导致 user 版本 adb  只拥有 shell  权限,而 eng 版本具有 root  权限



*       MTK System LOG  在 ICS 以后,在 user  版本默认关闭全部 LOG ,在 eng 版本中默认打开,以便抓到完整的资讯



*        在 eng 版本上, LOG  量  >= user  版本的 log 量,一些地方会直接 check eng/user 版本来确认是否打印 LOG



*       user  版本默认关闭 uart, eng 版本默认开启 uart



*        在 eng 版本上,开启 ANR  的 predump,  会抓取 ftrace ,可以得到更多 ANR 的资讯



*        在 eng 版本上,可用 rtt  抓取 backtrace ,可开启 kdb 进行 kernel debug, 可用 ftrace  抓取 cpu  执行场景



*       MTK aee  在 ENG 版本抓取更多的异常资讯,比如 native exception 会抓取 core dump 信息


(2)  性能方面,原则上进行性能测试请使用 user 版本测试



*       user  版本为提高第一次开机速度,使用了 DVM 的预优化,将 dex  文件分解成可直接 load  运行的 odex  文件, ENG 版本不会开启这项优化



*        更少的 LOG 打印, uart  的关闭,原则上 user  版本的性能要优于 eng  版本


(3)  如何确认 user/eng 版本



*        Java   层, checkandroid.os.Build 类中的 TYPE  值



*       native  层, property_get("ro.build.type",char* value, "eng"); 然后 check value 值



*       Debug  时,  adb shellgetprop ro.build.type 返回值如果是 user  即 user  版本, eng 即 eng  版本



*       Log  确认 ,  mobilelog/Aplog_xxxxx/versions 中查看 ro.build.type 属性