ADB 調試日志全攻略:如何開啟與關閉 `ADB_TRACE` 日志


ADB 調試日志全攻略:如何開啟與關閉 ADB_TRACE 日志

ADB(Android Debug Bridge)是 Android 開發的核心工具,但在排查問題時,默認日志可能不夠詳細。通過設置環境變量 ADB_TRACE,可以開啟 全量調試日志,幫助開發者定位問題。本文將詳細介紹如何開啟和關閉 ADB 日志,并解析常見場景。


1. 什么是 ADB_TRACE

ADB_TRACE 是 ADB 的一個環境變量,用于控制日志輸出的詳細程度。設置為 all 時,ADB 會打印所有模塊的調試信息(包括協議通信、設備連接、命令執行等),適用于:

  • 調試 ADB 連接問題
  • 分析設備通信異常
  • 排查 ADB 命令失敗原因

2. 如何開啟 ADB 全量日志?

方法 1:臨時開啟(當前終端會話有效)

Windows (CMD/PowerShell)
:: 設置環境變量(僅當前會話有效)
set ADB_TRACE=all:: 執行任意 ADB 命令(如查看設備列表)
adb devices
Linux/macOS (Bash/Zsh)
# 設置環境變量(僅當前會話有效)
export ADB_TRACE=all# 執行任意 ADB 命令
adb devices

效果
終端會輸出大量調試日志,例如:

adb trace: init: transport=usb
adb trace: protocol: sending 'host:devices'
adb trace: response: OKAY 1234567890

方法 2:永久開啟(不推薦)

如果需要長期開啟日志(如開發環境),可將變量寫入 Shell 配置文件:

Windows
  1. 打開 系統屬性高級環境變量
  2. 用戶變量 中新建變量:
    • 變量名:ADB_TRACE
    • 變量值:all
Linux/macOS

編輯 ~/.bashrc~/.zshrc,添加:

export ADB_TRACE=all

然后執行:

source ~/.bashrc  # 或 source ~/.zshrc

3. 如何關閉 ADB 日志?

方法 1:臨時關閉(當前終端會話)

Windows
:: 取消環境變量
set ADB_TRACE=:: 驗證日志是否關閉
adb devices
Linux/macOS
# 取消環境變量
unset ADB_TRACE# 驗證日志是否關閉
adb devices

效果
日志輸出恢復為默認簡潔模式,僅顯示關鍵信息(如設備列表)。


方法 2:關閉終端后重新打開

環境變量僅在當前終端會話中生效,直接關閉終端窗口即可徹底關閉日志。


方法 3:永久關閉(如果已寫入配置文件)

如果 ADB_TRACE 被永久寫入系統環境變量或 Shell 配置文件,需手動刪除:

Windows
  1. 打開 環境變量 窗口,刪除 ADB_TRACE 變量。
Linux/macOS

編輯 ~/.bashrc~/.zshrc,刪除或注釋以下行:

# export ADB_TRACE=all  # 刪除或注釋此行

然后執行:

source ~/.bashrc

4. 臨時覆蓋變量(單次命令禁用日志)

如果不想修改環境變量,但希望某條命令不輸出日志,可以臨時覆蓋:

Windows
:: 單次命令禁用日志
set ADB_TRACE= & adb devices
Linux/macOS
# 單次命令禁用日志
ADB_TRACE="" adb devices

5. 常見問題解答

Q1:日志太多看不過來怎么辦?

  • 使用 grep 過濾關鍵信息(Linux/macOS):
    adb devices 2>&1 | grep -i "error"
    
  • 將日志重定向到文件:
    adb devices > adb_log.txt 2>&1
    

Q2:為什么設置了 ADB_TRACE=all 但沒日志?

  • 檢查 ADB 版本是否過舊(需 ≥ 1.0.32):
    adb version
    
  • 確保變量拼寫正確(區分大小寫)。

Q3:日志會影響 ADB 性能嗎?

  • 會的!全量日志會顯著增加 I/O 和 CPU 負載,僅在調試時開啟

6. 總結

操作命令示例(Windows)命令示例(Linux/macOS)
開啟日志set ADB_TRACE=allexport ADB_TRACE=all
關閉日志set ADB_TRACE=unset ADB_TRACE
臨時覆蓋set ADB_TRACE= & adb ...ADB_TRACE="" adb ...
永久生效修改系統環境變量編輯 ~/.bashrc

推薦實踐

  • 調試問題時臨時開啟日志,完成后立即關閉。
  • 避免在生產環境或低性能設備上長期開啟日志。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/88760.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/88760.shtml
英文地址,請注明出處:http://en.pswp.cn/web/88760.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

實現druid數據源密碼加密

生成加密密碼集成了druid鏈接池的,可以實現數據源密碼加密。加密方式如下構建單元測試,并輸入密碼即可生成加密密碼以及加密公鑰Test public void testPwd() throws Exception {String password "123456";String[] arr com.alibaba.druid.fi…

【TCP/IP】20. 因特網安全

20. 因特網安全20. 因特網安全20.1 安全威脅20.2 安全服務20.3 基本安全技術20.3.1 密碼技術20.3.2 報文鑒別技術20.3.3 身份認證技術20.3.4 數字簽名技術20.3.5 虛擬專用網(VPN)技術20.3.6 防火墻技術20.3.7 防病毒技術20.4 IP 層安全20.5 傳輸層安全20…

數據結構之位圖和布隆過濾器

系列文章目錄 數據結構之ArrayList_arraylist o(1) o(n)-CSDN博客 數據結構之LinkedList-CSDN博客 數據結構之棧_棧有什么方法-CSDN博客 數據結構之隊列-CSDN博客 數據結構之二叉樹-CSDN博客 數據結構之優先級隊列-CSDN博客 常見的排序方法-CSDN博客 數據結構之Map和Se…

Web攻防-PHP反序列化魔術方法觸發條件POP鏈構造變量屬性修改黑白盒角度

知識點: 1.WEB攻防-PHP反序列化-序列化和反序列化 2.WEB攻防-PHP反序列化-常見魔術方法觸發規則 3.WEB攻防-PHP反序列化-反序列化漏洞產生原因 4.WEB攻防-PHP反序列化-黑白盒&POP鏈構造 一、演示案例-WEB攻防-PHP反序列化-序列化和反序列化 什么是反序列化操作…

C# VB.NET多進程-管道通信,命名管道(Named Pipes)

要向已運行的進程發送特定命令(如/exit),而不是啟動新進程,需要使用進程間通信(IPC)機制。以下是幾種常見的實現方法:一、使用命名管道(Named Pipes)如果ABC.EXE支持通過…

C++ 右值引用 (Rvalue References)

右值引用是C11引入的革命性特性,它徹底改變了C中資源管理和參數傳遞的方式。下面我將從多個維度深入講解右值引用。一、核心概念1. 值類別(Value Categories)lvalue (左值): 有標識符、可取地址的表達式int x 10; // x是左值 int* p &x; // 可以取地址rvalue…

反激變換器設計全流程(一)——電路拓撲及工作流程

一、電路拓撲原理 拓撲結構概述 開關反激電源采用反激式拓撲結構,主要由開關管(通常為 MOSFET)、變壓器、輸出整流二極管、輸出濾波電容以及控制電路等組成。其基本工作原理是通過開關管的周期性開關動作,將輸入直流電壓轉換為高…

uniapp語音播報天氣預報微信小程序

1.產品展示2.頁面功能(1)點擊上方按鈕實現語音播報4天天氣情況。3.uniapp代碼<template><view class"container"><view class"header"><text class"place">地址:{{city}}</text><text class"time"&g…

Pycharm 報錯 Environment location directory is not empty 如何解決

好長時間不看不寫代碼了&#xff0c;人也跟著犯糊涂。今天在Pycharm 導入虛擬環境時&#xff0c;一直報錯&#xff1a;“Environment location directory is not empty”&#xff0c;在網上百度很多很多方法都無法解決&#xff0c;直到我翻出我之前自己寫的導入虛擬環境的詳細過…

React強大且靈活hooks庫——ahooks入門實踐之場景類(scene)hook詳解

什么是 ahooks&#xff1f; ahooks 是一個 React Hooks 庫&#xff0c;提供了大量實用的自定義 hooks&#xff0c;幫助開發者更高效地構建 React 應用。其中場景類 hooks 是 ahooks 的一個重要分類&#xff0c;專門針對特定業務場景提供解決方案。 安裝 ahooks npm install …

大模型之Langchain篇(二)——RAG

寫在前面 跟著樓蘭老師學習【LangChain教程】2025吃透LangChain框架快速上手與深度實戰&#xff0c;全程干貨無廢話&#xff0c;三天學完&#xff0c;讓你少走百分之99彎路&#xff01;_嗶哩嗶哩_bilibili 計算相似度 一般用的余弦相似度&#xff0c;這里只是演示計算。 fr…

深入理解圖像二值化:從靜態圖像到視頻流實時處理

一、引言&#xff1a;圖像分析&#xff0c;從“黑與白”開始在計算機視覺任務中&#xff0c;**圖像二值化&#xff08;Image Binarization&#xff09;**是最基礎也是最關鍵的圖像預處理技術之一。它通過將灰度圖像中每個像素轉換為兩個離散值&#xff08;通常是0和255&#xf…

云蝠智能 VoiceAgent重構企業呼入場景服務范式

在數字化轉型浪潮中&#xff0c;企業呼入場景面臨客戶服務需求激增與人力成本攀升的雙重挑戰。傳統呼叫中心日均處理僅 300-500 通電話&#xff0c;人力成本占比超 60%&#xff0c;且服務質量受情緒波動影響顯著。云蝠智能推出的 VoiceAgent 語音智能體&#xff0c;通過全棧自研…

java進階(一)+學習筆記

1.JAVA設計模式1.1 什么是設計模式設計模式是軟件開發過程中前輩們在長期實踐中針對重復出現的問題總結出來的最佳解決方案。這些模式不是具體的代碼實現&#xff0c;而是經過驗證的、可重用的設計思想&#xff0c;能夠幫助開發者更高效地解決特定類型的問題。設計模式的重要性…

Pandas-數據清洗與處理

Pandas-數據清洗與處理一、數據清洗的核心目標二、缺失值處理1. 缺失值檢測2. 缺失值處理策略&#xff08;1&#xff09;刪除法&#xff08;2&#xff09;填充法三、異常值識別與處理1. 異常值檢測方法&#xff08;1&#xff09;統計法&#xff08;2&#xff09;業務規則法2. 異…

在 MacOS 上安裝和配置 Kafka

消息代理是一種軟件&#xff0c;充當在不同應用程序之間發送消息的中介。它的功能類似于服務器&#xff0c;從一個應用程序&#xff08;稱為生產者&#xff09;接收消息&#xff0c;并將其路由到一個或多個其他應用程序&#xff08;稱為消費者&#xff09;。消息代理的主要目的…

基于Leaflet調用天地圖在線API的多層級地名檢索實戰

目錄 前言 一、天地圖在線檢索 1、在線檢索功能 2、再談后后接口 二、Leaflet多層級實現實例 1、層級調用實現原理 2、Leaflet中多層級調用 3、成果展示 三、總結 前言 “地圖是世界的索引&#xff0c;而地名則是索引中的索引。”當互聯網地圖進入 Web 2.0 時代&#x…

基于Prompt結構的語校解析:3H日本語學校信息建模實錄(4/500)

基于Prompt結構的語校解析&#xff1a;3H日本語學校信息建模實錄&#xff08;4/500&#xff09; 系列延續&#xff1a;500所日本語言學校結構數據工程 關鍵詞&#xff1a;招生結構、JLPTEJU、國籍比例、認定校、Prompt訓練集 一、我們在構建什么樣的語言學校語料&#xff1f; …

Leaflet面試題及答案(61-80)

查看本專欄目錄 文章目錄 ?? 面試問題及答案(61-80)61. 如何在地圖上顯示一個動態更新的圖層?62. 如何實現地圖上的熱力圖(Heatmap)?63. 如何自定義地圖控件的位置?64. 如何處理地圖加載失敗的情況?65. 如何實現地圖的離線功能?66. 如何將地圖導出為圖片?67. 如何實…

MIG_IP核的時鐘系統

MIG_IP核的時鐘系統時鐘的種類和配置時鐘的種類和配置 整體框圖 DDR_PHY_CLK&#xff1a;DDR3的工作頻率&#xff0c;用來得到想要的線速率。假設此時鐘為800M&#xff0c;那么DDR雙沿采樣&#xff0c;線速率為1600Mbit&#xff1b; UI_CLK&#xff1a;DDR_PHY_CLK的四分之一…