這篇文章主要講解了Android PC端用ADB抓取指定應用日志的實現(xiàn)方法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)咸寧免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
主要功能:
用于在PC端通過ADB工具抓取指定android真機上運行的指定包名應用的調(diào)試日志,并生成本地txt文件。
實現(xiàn)步驟:
1、準備ADB調(diào)試軟件;
2、根據(jù)包名找到進程pid;
新建一個txt文件,重命名為“getpid.bat”,把下面代碼復制到該文檔中,保存;
包名“com.wtoe.demo”可替換為自己所需要抓取日志的包名。
@echo off
adb shell "ps | grep com.wtoe.demo"
3、根據(jù)包名找到進程pid;
新建一個txt文件,重命名為“catlog.bat”,把下面代碼復制到該文檔中,保存
文件路徑“F:/android_log/001.log ”可替換為自己電腦的任意文件路徑;文件無需創(chuàng)建,運行時,會自動創(chuàng)建。
@echo off for /f "tokens=2 delims= " %%i in ('getpid.bat') do adb logcat | find "%%i" > F:/android_log/001.log pause
#如果該包名有多個進程pid(守護進程等),都會打印到日志中。
4、將腳本文件“getpid.bat”、“catlog.bat”剪切到adb目錄中
5、將android手機用數(shù)據(jù)線連接電腦,手機打開開發(fā)者調(diào)試模式(若未開啟開發(fā)者模式,一般可以進入系統(tǒng)-關于手機-全部參數(shù) 等界面,連續(xù)點擊版本7次左右可開啟)
6、點擊運行“cmd.exe”,先運行命令“adb devices”,查看是否有真機連接上電腦adb。
7、雙擊運行 “catlog.bat”即可(不要關閉命令窗口,關閉窗口即停止抓取日志)。
8、查看日志文件。可能存在中文字符亂碼的問題,更改編碼格式就可以了。
補充知識:android studio帶文件和行輸出的logcat
實現(xiàn)的效果
因之前寫的C/C++打印都是帶上文件名和行數(shù)的,自學到android 的logcat,發(fā)現(xiàn)錯誤時候會直接鼠標點擊跳轉(zhuǎn)到相應的代碼處,遂自己封裝下一個函數(shù),能夠打印文件,行數(shù)并且支持直接的鼠標跳轉(zhuǎn),很方便調(diào)試。deep參數(shù)可以自定義深度,比如 1 代表上一個方法的調(diào)用處,但是有時候可能有問題,不帶深度的打印目前沒有發(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(); } }
看完上述內(nèi)容,是不是對Android PC端用ADB抓取指定應用日志的實現(xiàn)方法有進一步的了解,如果還想學習更多內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁標題:AndroidPC端用ADB抓取指定應用日志的實現(xiàn)方法
標題網(wǎng)址:http://www.chinadenli.net/article0/iioeoo.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、服務器托管、關鍵詞優(yōu)化、標簽優(yōu)化、網(wǎng)站營銷、云服務器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)