Android應用程序調試Logcat的使用

Android的程序調試主要使用Logcat進行,本節主要介紹Logcat的使用。

  1. 開啟調試模式

使用Android Studio進行程序調試,首先需要連接虛擬Android設備或真實Android設備,設備上需要啟用調試功能。

虛擬Android設備默認情況下會啟用調試功能。對于真實Android設備,需要在設備開發者選項中啟用調試功能。Android設備的開發者選項一般在設置App里可以找到,在該界面中可以配置一些系統行為來幫助分析和調試應用性能,例如,可以啟用 USB 調試、捕獲 bug 報告、啟用點按的視覺反饋、在窗口 surface 更新時刷寫 surface、使用 GPU 渲染 2D 圖形等等。

不同版本的Android啟用開發者選項的方法不同,在 Android 4.1 及更低版本上,開發者選項界面在默認情況下處于啟用狀態。在 Android 4.2 及更高版本上,必須手動啟用此界面。

大部分Android設備啟動開發者選項的方法是找到“設置”中的“關于手機”,再找到“版本號”,連續點按版本號選項七次,直到看到 “您已處于開發者模式,無需進行此操作。” 或類似消息。

注意在某些設備上,開發者選項界面所在的位置或所用的名稱可能有所不同,具體請搜索各自品牌手機開發使用說明。

在開發者選項界面需要啟用 USB 調試,以便 Android Studio 和其他 SDK 工具能夠通過 USB 連接時識別設備,然后才能使用調試工具和其他工具,如圖1所示。

圖1 開啟開發者選項和USB調試

Android 11及以上系統還支持無線調式,無需使用數據線即可進行程序調試,無線調試開啟方法與USB調試類似,具體使用步驟讀者可查閱相關資料。

2.使用 Logcat 查看日志

Android Studio中的 Logcat 窗口會實時顯示設備日志,日志有來自在 Android 上運行的服務的消息或系統消息、當前調試應用的消息。

如需查看應用的日志消息,執行以下操作。

1)在 Android Studio中,在實體設備或模擬器上構建并運行應用。

2)從菜單欄中依次選擇 View → Tool Windows → Logcat。

3)默認情況下,Logcat 會滾動到末尾。單擊 Logcat 視圖或使用鼠標滾輪向上滾動即可關閉此功能。如需重新開啟,請單擊工具欄中的“Scroll to the End”圖標,還可以使用工具欄清除、暫停或重啟 Logcat。

如果應用拋出異常,Logcat 會顯示一條消息,后跟相關聯的堆棧軌跡,其中包含指向相應代碼行的鏈接,如圖2圖中藍色字“MainActivty.java:19”即表示錯誤出現在MainActivty.java文件的第19行,單擊該藍色字即可跳轉到出錯代碼處。

圖2 ?Logcat示例

3.搜索查詢日志

在 Android Studio中,可以直接從主查詢字段生成鍵值對搜索所需日志。以下是可以在查詢中使用的鍵:

  1. tag:與日志條目的 tag 字段匹配。
  2. package:與日志記錄應用的軟件包名稱匹配。
  3. process:與日志記錄應用的進程名稱匹配。
  4. message:與日志條目的消息部分匹配。
  5. level:與指定或更高嚴重級別的日志匹配,例如 DEBUG。
  6. age:如果條目時間戳是最近的,則匹配。值要指定為數字,后跟表示時間單位的字母:s 表示秒,m 表示分鐘,h 表示小時,d 表示天。例如,age: 5m 只會過濾過去 5 分鐘內記錄的消息。

如圖3所示,在日志搜索框中輸入tag,可以看到支持的tag匹配模式,包括精確匹配、包含、正則表達式匹配、不包含等。

圖3 ?Logcat tag鍵值匹配模式

圖4?Logcat message鍵值匹配模式

圖5 ?Logcat package:mine匹配模式

大部分其他鍵同樣有這些匹配模式,如圖4所示是message鍵的匹配模式,除此之外,還有個特殊查詢: package:mine,表示當前包名下的所有日志信息,如圖5所示。

level 查詢與 Logcat 消息的日志級別匹配,其中日志條目的級別大于或等于查詢級別。例如,level:INFO 匹配日志級別為 INFO、WARN、ERROR 或 ASSERT 的任何日志條目,級別不區分大小寫,如圖6所示。有效級別包括:VERBOSE、DEBUG、INFO、WARN、ERROR 和 ASSERT。

圖6? Logcat level:INFO匹配模式

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

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

相關文章

C++ 入門03:函數與作用域

往期回顧: C 入門01:初識 C-CSDN博客C 入門02:控制結構和循環-CSDN博客 一、前言 在前面的文章學習中,我們了解了C語言的基礎,包括如何定義變量來存儲數據,以及如何利用輸入輸出流實現程序與用戶之間的無縫…

華為機考真題 -- 找朋友

題目描述: 在學校中,N 個小朋友站成一隊, 第 i 個小朋友的身高為 height[i],第 i 個小朋友可以看到的第一個比自己身高更高的小朋友 j,那么 j 是 i 的好朋友(要求 j >i)。請重新生成一個列表,對應位置的輸出是每個小朋友的好朋友位置,如果沒有看到好朋友,請在該位置…

微軟清華提出全新預訓練范式,指令預訓練讓8B模型實力暴漲!實力碾壓70B模型

現在的大模型訓練通常會包括兩個階段: 一是無監督的預訓練,即通過因果語言建模預測下一個token生成的概率。該方法無需標注數據,這意味著可以利用大規模的數據學習到語言的通用特征和模式。 二是指令微調,即通過自然語言指令構建…

Python面試題:請解釋什么是鴨子類型(duck typing)?

鴨子類型(Duck Typing)是一種動態類型語言中的概念,它基于對象的行為(方法和屬性)而不是其實際類型進行判斷。這個概念源自詹姆斯惠特科姆賴利的諺語: “如果它走起來像鴨子,叫起來像鴨子&#…

通過高德地圖 JS API實現單擊鼠標進行標注

效果圖: 核心代碼: <template><a-modal title="選擇地圖所在位置" :width="width" :visible="visible" @ok="handleOk" @cancel="handleCancel" cancelText="關閉"><div class="location-…

場外期權有交割日嗎?場外期權應該怎么交割?

今天帶你了解場外期權有交割日嗎&#xff1f;場外期權應該怎么交割&#xff1f;場外個股期權是一種非標準化的金融衍生品&#xff0c;它允許投資者在未來某一特定日期以特定價格買入或賣出某一特定股票。 交割日就是買賣雙方進行交割的日期,期權合約具有到期日,到期日的后一天…

WEB安全-文件上傳漏洞

1 需求 2 接口 3 MIME類型 在Web開發中&#xff0c;MIME&#xff08;Multipurpose Internet Mail Extensions&#xff09;類型用于標識和表示文檔的格式。這些類型在HTTP請求和響應頭中扮演著重要的角色&#xff0c;告訴瀏覽器如何解釋和處理接收到的資源12。 以下是一些Web開發…

ChatGPT:Java Stream 的疑問

ChatGPT&#xff1a;Java Stream 的疑問 解釋一下 List<SupplierVm> collect tSupplierPage.getRecords().stream().map(item ->{SupplierVm supplierVm new SupplierVm();BeanUtils.copyProperties(item, supplierVm);return supplierVm;}).collect(Collectors.to…

【JavaScript】具有 iterable 接口的數據結構

具有 iterable 接口的數據結構指的是可以通過迭代器&#xff08;Iterator&#xff09;訪問其成員的數據結構。在 JavaScript 中&#xff0c;具有 iterable 接口的數據結構包括數組&#xff08;Array&#xff09;、字符串&#xff08;String&#xff09;、Set、Map 等。這些數據…

C電池 和 D 電池的作用和類型詳解及其之間的區別

C 和 D 電池是我們日常生活中必不可少的部件。它們通常用于高功率設備。例如手電筒和玩具。 D 型電池和 C 型電池是兩種常見的電池類型。它們是一次性圓柱形電池。您可以在很多設備上使用它們。雖然它們有很多相似之處&#xff0c;但它們也有不同的特點。這些特點使它們適合某…

如何用qq郵箱注冊outlook郵箱

&#x1f4d1;打牌 &#xff1a; da pai ge的個人主頁 &#x1f324;?個人專欄 &#xff1a; da pai ge的博客專欄 ??寶劍鋒從磨礪出&#xff0c;梅花香自苦寒來 ? 目錄 第一步輸入qq郵箱 第二步…

數據類型及數據塊認知

西門子STEP7編程語言 梯形圖(LAD) 功能塊圖(FBD) 語句表(STL) 其中梯形圖和功能塊圖可以相互轉換 CPU常用數據區 信號輸入區 I 信號輸出區 Q 程序中表現形式&#xff0c;IX.X/QX.X;IWX/QWX-訪問的是CPU輸出輸入過程映像區 另一種形式IWX:P/QWX:P-訪問的是信號端口地址&#xf…

深度整合全球資源,分貝通打造高效、合規的海外差旅管理平臺

在全球化商業活動的背景下,中國企業出海已成為常態。然而,隨著海外差旅市場的全面增長,企業在海外支出管理上面臨諸多挑戰。據2023年數據顯示,分貝通出海差旅業務GMV同比增長高達500倍,這一增長背后隱藏著企業對于更省錢、更高效管控方式的迫切需求。 面對與日俱增的開支,企業開…

js對象的方法速覽---數組的靜態方法,實例方法和屬性合集,各包含一個示例

tip&#xff1a; 本文僅作為查找和基本使用的展示&#xff0c;需要深入了解這些方法的使用請參考&#xff1a;Object - JavaScript | MDN (mozilla.org) 可以通過目錄快速鎖定需要查找的方法和查看它的使用 目錄 tip&#xff1a; 新建一個對象 實例屬性 實例方法 hasOwn…

Websocket 替代方案:如何使用 Firestore 監聽實時事件

大家好,我是CodeQi! 一位熱衷于技術分享的碼仔。 ?在現代 Web 開發中,實時更新功能對于許多應用程序(如聊天應用、協作工具和在線游戲)都是必不可少的。雖然 WebSocket 是一種常用的實時通信技術,但 Google 的 Firestore 也提供了一種強大的替代方案,使得實時監聽變得…

Golang中defer和return順序

在Golang中&#xff0c;defer 和 return 的執行順序是一個重要的特性&#xff0c;它們的執行順序如下&#xff1a; return語句不是一條單獨的語句&#xff0c;實際上&#xff0c;它是由賦值和返回兩部分組成的。賦值步驟會先執行&#xff0c;這一步會計算return語句中的表達式…

Linux安裝Docker以及Docker Componse

一、安裝前準備工作 1.1 查看服務器系統版本以及內核版本 cat /etc/redhat-release 1.2 查看服務器內核版本 uname -r這里我們使用的是CentOS 7.4 系統&#xff0c;內核版本為3.10 1.3 安裝依賴包 yum install -y yum-utils device-mapper-persistent-data lvm21.4 設置…

賽氪網受邀出席浙江省應用數學研究會,共啟數學教育與競賽新篇章

2024年7月5日&#xff0c;浙江省應用數學研究會在風景如畫的嘉興市成功舉辦了2024年學術研討會暨第七屆第六次理事會工作會議的首日活動。作為技術支持單位&#xff0c;賽氪網受邀參與此次盛會&#xff0c;彰顯了其在數學教育及競賽領域的深厚實力與積極貢獻。 開幕式由嘉興大學…

linux watchdog 子系統

目錄 一、watchdog 子系統二、關鍵數據結構2.1 watchdog_device2.2 watchdog_ops2.3 watchdog_info 三、重要流程3.1 watchdog 初始化3.2 watchdog 設備注冊3.3 watchdog 設備文件操作函數3.4 watchdog 喂狗用戶空間 watchdog&#xff08;busybox&#xff09;內核空間喂狗疑問 …

生成隨機密碼

生成8位無重復的密碼&#xff08;可以包含數字、大小寫字母&#xff09; import random import string character string.digits string.ascii_letters password .join(random.sample(character, 8)) print(f"生成的隨機密碼為:{password}")