adb log抓取方法


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 属性
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值