前言
最新項目里一直在做 Android RIL 方面的研究,非常最終項目還是未能解決通信底層模塊的問題,但是在使用adb抓log上還是有一些收獲的,這里記錄一下。
Log分類
Android日志主要分為kernel、radio、event、main這四種log。
Kernel Log
kernel log屬於Linux內核的log ,可以通過讀取/proc/kmsg或者通過串口來抓取。
adb 抓取kernel log的命令如下(需要有root權限):
- adb shell cat /proc/kmsg > /tmp/kernel.log
Radio Log
-b radio參數可以抓取Android RIL層 log,在調試Android通信方面的代碼時,這個Log非常關鍵。抓取命令如下:
- adb logcat -b radio > /tmp/radio.log
Main Log
main log和我們在eclipse里通過DDMS中看到的log是一致的。抓取命令如下:
- adb logcat -b main > /tmp/main.log
Event Log
event log屬於system log,平時可以跟在main log之后。抓取命令如下:
- adb logcat -b event -v time > /tmp/event.log
-v time表示在log中加入每條log發生的時間。
完整Log
adb logcat -b選項是可以復用的,因此我們抓取所有Log的命令就是復用了-b選項。抓取命令如下:
- adb logcat -b main -b system -b radio -b events -v time > /tmp/all.log