欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android shell命令行中過濾adb logcat輸出的幾種方法

 更新時間:2016年08月11日 17:28:21   投稿:lqh  
本文主要介紹Android shell命令行中過濾adb logcat輸出的方法,這里整理了幾種方法,并詳細的說明,有需要的朋友可以參考下

我們在Android開發(fā)中總能看到程序的log日志內容充滿了屏幕,而真正對開發(fā)者有意義的信息被淹沒在洪流之中,讓開發(fā)者無所適從,嚴重影響開發(fā)效率。本文就具體介紹幾種在shell命令行中過濾adb logcat輸出的方法。

       1、只顯示需要的輸出(白名單)

       最方便的當然是通過管道使用 grep 過濾了,這樣可以使用 grep 強大的正則表達式匹配。簡單的匹配一行當中的某個字符串,例如 MyApp:

  1.        adb logcat | grep MyApp
  2.        adb logcat | grep -i myapp #忽略大小寫。
  3.        adb logcat | grep --color=auto -i  myapp #設置匹配字符串顏色。更多設置請查看 grep 幫助。

      進階一點可以使用 grep 的正則表達式匹配。例如上一個例子會匹配一行中任意位置的 MyApp,可以設置為僅匹配 tag。默認的 log 輸出如下,如果修改過輸出格式相應的表達式也要修改。

       I/CacheService(  665): Preparing DiskCache for all thumbnails.

       可以看出 tag 是一行開頭的第三個字符開始,根據(jù)這點寫出表達式:

       adb logcat | grep "^..MyApp"

       根據(jù)這個格式也可以設置只顯示某個優(yōu)先級的 log,再匹配行首第一個字符即可。例如僅顯示 Error 級別 tag 為 MyApp 的輸出:

       adb logcat | grep "^E.MyApp"

       當然也可以匹配多個,使用 | 分割多個匹配表達式,要加轉義符。例如要匹配 tag 為 MyApp 和 MyActivity 的輸出:

       adb logcat | grep "^..MyApp\|^..MyActivity"
       adb logcat | grep -E "^..MyApp|^..MyActivity"  #使用 egrep 無須轉義符

       2、過濾不需要的輸出(黑名單)

       還是使用 grep,用法也跟上面的一樣,加一個 -v 即可。例如要過濾 tag 為 MyApp 和 MyActivity 的輸出:

       adb logcat | grep -v "^..MyApp\|^..MyActivity"
       adb logcat | grep -vE "^..MyApp|^..MyActivity"  #使用 egrep 無須轉義符

       3、顯示同一個進程的所有輸出

       有時一個程序里面的 tag 有多個,需要輸出該程序(同一個 PID)的所有 tag;僅使用 tag 過濾有時也會漏掉一些錯誤信息,而一般錯誤信息也是和程序同一個 PID。還是通過 grep 實現(xiàn),思路是先根據(jù)包名找到 pid 號,然后匹配 pid。寫成 shell 腳本如下,參數(shù)是程序的 java 包名(如 com.android.media)。

  #!/bin/bash
  packageName=$1
  pid=`adb shell ps | grep $packageName | awk ‘{print $2}'`
  adb logcat | grep –color=auto $pid

       4、從當前開始顯示

       logcat 有緩存,如果僅需要查看當前開始的 log,需要清空之前的。

       adb logcat -c && adb logcat

       5、過濾 log 文件

       有時需要分析 log 文件,過濾 log 文件還是使用 grep。例如 log 文件為 myapp.log,要匹配 tag 為 MyApp 和 MyActivity 的輸出,然后輸出到 newmyapp.log:

       cat myapp.log | grep "^..MyApp\|^..MyActivity" > newmyapp.log

       Windows 下推薦使用Notepad++,一個免費強大的記事本,支持正則表達式查找替換。可以高亮顯示匹配內容,也可以刪除不需要的內容。

       以上的技巧主要用到了 grep,其實 logcat 本身也有過濾功能,可以根據(jù) tag、優(yōu)先級過濾 log,具體請參考 Android 官方文檔Reading and Writing Logs。如果喜歡使用圖形界面,請參考Using DDMS,DDMS 里面的 logcat 也可以同樣過濾。

以上就是Android shell命令行中過濾adb logcat輸出的幾種方法的資料整理,后續(xù)繼續(xù)補充相關資料,謝謝大家對本站的支持!

相關文章

  • 詳解Android中的Service

    詳解Android中的Service

    這篇文章主要介紹了Android中的Service,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-03-03
  • Cocos2d-x 3.0多線程異步加載資源實例

    Cocos2d-x 3.0多線程異步加載資源實例

    手機游戲,即便是休閑類的小游戲,往往也涉及大量紋理資源、音視頻資源、文件讀寫以及網(wǎng)絡通信,處理的稍有不甚就會出現(xiàn)畫面卡頓,交互不暢的情況
    2014-04-04
  • Android 架構之數(shù)據(jù)庫框架搭建

    Android 架構之數(shù)據(jù)庫框架搭建

    這篇文章主要給大家介紹的是Android 架構之數(shù)據(jù)庫框架搭建,在本篇中,將會讓你一點一滴從無到有創(chuàng)建一個不再為數(shù)據(jù)庫而煩惱的框架。需要的朋友可以參考下面文章的具體內容
    2021-09-09
  • Android?Activity生命周期調用的理解

    Android?Activity生命周期調用的理解

    大家好。本篇文章主要講的是Android?Activity生命周期調用的理解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 解決Android 10/Android Q手機在后臺無法正常定位問題

    解決Android 10/Android Q手機在后臺無法正常定位問題

    這篇文章主要介紹了解決Android 10/Android Q手機在后臺無法正常定位問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Android實現(xiàn)三段式滑動效果

    Android實現(xiàn)三段式滑動效果

    最近發(fā)現(xiàn)很多app都使用了三段式滑動,比如說高德的首頁和某寶等物流信息都是使用的三段式滑動方式,谷歌其實給了我們很好的2段式滑動,就是BottomSheet,所以這次我也是在這個原理基礎上做了一個小小的修改來實現(xiàn)我們今天想要的效果。
    2021-06-06
  • 如何使用Flutter開發(fā)一款電影APP詳解

    如何使用Flutter開發(fā)一款電影APP詳解

    這篇文章主要給大家介紹了關于如何使用Flutter開發(fā)一款電影APP的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Flutter具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • Kotlin協(xié)程開發(fā)之Flow的融合與Channel容量及溢出策略介紹

    Kotlin協(xié)程開發(fā)之Flow的融合與Channel容量及溢出策略介紹

    這篇文章主要介紹了Kotlin協(xié)程:Flow的融合、Channel容量、溢出策略,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-09-09
  • Android實現(xiàn)蝸牛進度條效果

    Android實現(xiàn)蝸牛進度條效果

    這篇文章主要為大家詳細介紹了Android實現(xiàn)蝸牛進度條效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Flutter?異步編程之單線程下異步模型圖文示例詳解

    Flutter?異步編程之單線程下異步模型圖文示例詳解

    這篇文章主要為大家介紹了Flutter?異步編程之單線程下異步模型圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09

最新評論