AndroidPC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法

這篇文章主要講解了Android PC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

專(zhuān)注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)咸寧免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

主要功能:

用于在PC端通過(guò)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 off
adb shell "ps | grep com.wtoe.demo"

3、根據(jù)包名找到進(jìn)程pid;

新建一個(gè)txt文件,重命名為“catlog.bat”,把下面代碼復(fù)制到該文檔中,保存

文件路徑“F:/android_log/001.log ”可替換為自己電腦的任意文件路徑;文件無(wú)需創(chuàng)建,運(yùn)行時(shí),會(huì)自動(dò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

#如果該包名有多個(gè)進(jìn)程pid(守護(hù)進(jìn)程等),都會(huì)打印到日志中。

4、將腳本文件“getpid.bat”、“catlog.bat”剪切到adb目錄中

Android PC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法

5、將android手機(jī)用數(shù)據(jù)線(xiàn)連接電腦,手機(jī)打開(kāi)開(kāi)發(fā)者調(diào)試模式(若未開(kāi)啟開(kāi)發(fā)者模式,一般可以進(jìn)入系統(tǒng)-關(guān)于手機(jī)-全部參數(shù) 等界面,連續(xù)點(diǎn)擊版本7次左右可開(kāi)啟)

6、點(diǎn)擊運(yùn)行“cmd.exe”,先運(yùn)行命令“adb devices”,查看是否有真機(jī)連接上電腦adb。

7、雙擊運(yùn)行 “catlog.bat”即可(不要關(guān)閉命令窗口,關(guān)閉窗口即停止抓取日志)。

8、查看日志文件??赡艽嬖谥形淖址麃y碼的問(wèn)題,更改編碼格式就可以了。

補(bǔ)充知識(shí):android studio帶文件和行輸出的logcat

實(shí)現(xiàn)的效果

Android PC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法

因之前寫(xiě)的C/C++打印都是帶上文件名和行數(shù)的,自學(xué)到android 的logcat,發(fā)現(xiàn)錯(cuò)誤時(shí)候會(huì)直接鼠標(biāo)點(diǎn)擊跳轉(zhuǎn)到相應(yīng)的代碼處,遂自己封裝下一個(gè)函數(shù),能夠打印文件,行數(shù)并且支持直接的鼠標(biāo)跳轉(zhuǎn),很方便調(diào)試。deep參數(shù)可以自定義深度,比如 1 代表上一個(gè)方法的調(diào)用處,但是有時(shí)候可能有問(wèn)題,不帶深度的打印目前沒(méi)有發(fā)現(xiàn)問(wè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)容,是不是對(duì)Android PC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁(yè)標(biāo)題:AndroidPC端用ADB抓取指定應(yīng)用日志的實(shí)現(xiàn)方法
標(biāo)題網(wǎng)址:http://muchs.cn/article0/iioeoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開(kāi)發(fā)服務(wù)器托管、關(guān)鍵詞優(yōu)化、標(biāo)簽優(yōu)化網(wǎng)站營(yíng)銷(xiāo)、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)