Android PC端用ADB抓取指定應(yīng)用日志實現(xiàn)步驟
主要功能:
用于在PC端通過ADB工具抓取指定android真機(jī)上運(yùn)行的指定包名應(yīng)用的調(diào)試日志,并生成本地txt文件。
實現(xiàn)步驟:
1、準(zhǔn)備ADB調(diào)試軟件;
2、根據(jù)包名找到進(jìn)程pid;
新建一個txt文件,重命名為“getpid.bat”,把下面代碼復(fù)制到該文檔中,保存;
包名“com.wtoe.demo”可替換為自己所需要抓取日志的包名。
@echo off
adb shell "ps | grep com.wtoe.demo"
3、根據(jù)包名找到進(jìn)程pid;
新建一個txt文件,重命名為“catlog.bat”,把下面代碼復(fù)制到該文檔中,保存
文件路徑“F:/android_log/001.log ”可替換為自己電腦的任意文件路徑;文件無需創(chuàng)建,運(yùn)行時,會自動創(chuàng)建。
@echo off
for /f "tokens=2 delims= " %%i in ('getpid.bat') do adb logcat | find "%%i" > F:/android_log/001.log
pause
#如果該包名有多個進(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
實現(xiàn)的效果

因之前寫的C/C++打印都是帶上文件名和行數(shù)的,自學(xué)到android 的logcat,發(fā)現(xiàn)錯誤時候會直接鼠標(biāo)點(diǎn)擊跳轉(zhuǎn)到相應(yīng)的代碼處,遂自己封裝下一個函數(shù),能夠打印文件,行數(shù)并且支持直接的鼠標(biāo)跳轉(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();
}
}
以上這篇Android PC端用ADB抓取指定應(yīng)用日志實現(xiàn)步驟就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Android設(shè)備adb連接后顯示device unauthorized解決方案
- 基于adbkit的android設(shè)備管理(精簡版stf)
- android中的adb命令學(xué)習(xí)
- 超詳細(xì)的Android開發(fā)調(diào)試工具ADB命令及安裝介紹
- android中adb命令最全總結(jié)
- 詳解android adb常見用法
- adb通過wifi連接android設(shè)備流程解析
- Android adb命令中pm工具的作用及用法說明
- Android adb安裝apk時提示Invalid APK file的問題
- Android user版通過adb_enable開啟adb 調(diào)試 不提示對話框的流程分析
- Android 實現(xiàn)永久性開啟adb 的root權(quán)限
- 關(guān)于ADB的Android Debug Bridge(安卓調(diào)試橋)那些事
- Android客制化adb shell進(jìn)去后顯示shell@xxx的標(biāo)識
- android設(shè)置adb自帶screenrecord錄屏命令
- Android 修改adb端口的方法
- Android中ADB命令用法大結(jié)局
- Android開啟ADB網(wǎng)絡(luò)調(diào)試方法
- Android ADB簡介、安裝及使用詳解
相關(guān)文章
Android ScrollView只能添加一個子控件問題解決方法
這篇文章主要介紹了Android ScrollView只能添加一個子控件問題解決方法,涉及Android界面布局的相關(guān)技巧,需要的朋友可以參考下2016-02-02
Android超詳細(xì)介紹自定義多選框與點(diǎn)擊按鈕跳轉(zhuǎn)界面的實現(xiàn)
這篇文章主要介紹了在Android開發(fā)中如何來實現(xiàn)自定義多選框以及如何實現(xiàn)點(diǎn)擊按鈕跳轉(zhuǎn)界面的功能,感興趣的朋友快來看看吧2022-03-03
Android使用RecyclerView實現(xiàn)列表數(shù)據(jù)選擇操作
這篇文章主要為大家詳細(xì)介紹了Android使用RecyclerView結(jié)合CheckBox實現(xiàn)列表數(shù)據(jù)選擇操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
Android使用socket創(chuàng)建簡單TCP連接的方法
這篇文章主要介紹了Android使用socket創(chuàng)建簡單TCP連接的方法,結(jié)合實例形式詳細(xì)分析了Android使用socket創(chuàng)建TCP連接的具體步驟與實現(xiàn)技巧,需要的朋友可以參考下2016-04-04
揭秘雙十一手機(jī)淘寶圖標(biāo)如何被動態(tài)更換
這篇文章主要介紹了每到雙十一十二的時候Android手機(jī)動態(tài)更換手機(jī)圖標(biāo)的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08
android實現(xiàn)直播點(diǎn)贊飄心動畫效果
這篇文章主要為大家詳細(xì)介紹了android實現(xiàn)直播點(diǎn)贊飄心動畫效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03
android使用SharedPreferences進(jìn)行數(shù)據(jù)存儲
Android平臺給我們提供了一個SharedPreferences類,它是一個輕量級的存儲類,特別適合用于保存軟件配置參數(shù)。有興趣的可以了解一下。2017-02-02

