Android PC端用ADB抓取指定應(yīng)用日志實(shí)現(xiàn)步驟
主要功能:
用于在PC端通過ADB工具抓取指定android真機(jī)上運(yùn)行的指定包名應(yīng)用的調(diào)試日志,并生成本地txt文件。
實(shí)現(xiàn)步驟:
1、準(zhǔn)備ADB調(diào)試軟件;
2、根據(jù)包名找到進(jìn)程pid;
新建一個(gè)txt文件,重命名為“getpid.bat”,把下面代碼復(fù)制到該文檔中,保存;
包名“com.wtoe.demo”可替換為自己所需要抓取日志的包名。
@echo offadb shell 'ps | grep com.wtoe.demo'
3、根據(jù)包名找到進(jìn)程pid;
新建一個(gè)txt文件,重命名為“catlog.bat”,把下面代碼復(fù)制到該文檔中,保存
文件路徑“F:/android_log/001.log ”可替換為自己電腦的任意文件路徑;文件無需創(chuàng)建,運(yùn)行時(shí),會自動創(chuàng)建。
@echo offfor /f 'tokens=2 delims= ' %%i in (’getpid.bat’) do adb logcat | find '%%i' > F:/android_log/001.log pause
#如果該包名有多個(gè)進(jìn)程pid(守護(hù)進(jìn)程等),都會打印到日志中。
4、將腳本文件“getpid.bat”、“catlog.bat”剪切到adb目錄中
5、將android手機(jī)用數(shù)據(jù)線連接電腦,手機(jī)打開開發(fā)者調(diào)試模式(若未開啟開發(fā)者模式,一般可以進(jìn)入系統(tǒng)-關(guān)于手機(jī)-全部參數(shù) 等界面,連續(xù)點(diǎn)擊版本7次左右可開啟)
6、點(diǎn)擊運(yùn)行“cmd.exe”,先運(yùn)行命令“adb devices”,查看是否有真機(jī)連接上電腦adb。
7、雙擊運(yùn)行 “catlog.bat”即可(不要關(guān)閉命令窗口,關(guān)閉窗口即停止抓取日志)。
8、查看日志文件。可能存在中文字符亂碼的問題,更改編碼格式就可以了。
補(bǔ)充知識:android studio帶文件和行輸出的logcat
實(shí)現(xiàn)的效果
因之前寫的C/C++打印都是帶上文件名和行數(shù)的,自學(xué)到android 的logcat,發(fā)現(xiàn)錯(cuò)誤時(shí)候會直接鼠標(biāo)點(diǎn)擊跳轉(zhuǎn)到相應(yīng)的代碼處,遂自己封裝下一個(gè)函數(shù),能夠打印文件,行數(shù)并且支持直接的鼠標(biāo)跳轉(zhuǎn),很方便調(diào)試。deep參數(shù)可以自定義深度,比如 1 代表上一個(gè)方法的調(diào)用處,但是有時(shí)候可能有問題,不帶深度的打印目前沒有發(fā)現(xiàn)問題。
package m.hajistark.main;import android.util.Log;/** * Created by hajistark on 2019/2/18. */public class LogPrint { private static String TAG = 'conlog '; public static String Line() { StackTraceElement ste = new Throwable().getStackTrace()[2]; return '(' + ste.getFileName() + ':' + ste.getLineNumber() + ') '; } public static String Line(int deep) { StackTraceElement ste = new Throwable().getStackTrace()[2 + deep]; return '(' + ste.getFileName() + ':' + ste.getLineNumber() + ') '; } public static void i(String Str) { Log.i(TAG + Line(), Str); } public static void w(String Str) { Log.w(TAG + Line(), Str); } public static void d(String Str) { Log.d(TAG + Line(), Str); } public static void d(String Str, int deep) { Log.d(TAG + Line(deep + 1), Str); } public static void e(String Str) { Log.e(TAG + Line(), Str); } public static void e(String Str, int deep) { Log.e(TAG + Line(deep + 1), Str); } public static void c(Exception e) { e.printStackTrace(); }}
以上這篇Android PC端用ADB抓取指定應(yīng)用日志實(shí)現(xiàn)步驟就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 使用ProcessBuilder調(diào)用外部命令,并返回大量結(jié)果2. 關(guān)于Mysql-connector-java驅(qū)動版本問題總結(jié)3. 使用css實(shí)現(xiàn)全兼容tooltip提示框4. JSP實(shí)現(xiàn)客戶信息管理系統(tǒng)5. 通過工廠模式返回Spring Bean方法解析6. python 批量下載bilibili視頻的gui程序7. python中HTMLParser模塊知識點(diǎn)總結(jié)8. CSS自定義滾動條樣式案例詳解9. Ajax提交post請求案例分析10. python:刪除離群值操作(每一行為一類數(shù)據(jù))
