adb獲取Android性能數據


環境:Android測試環境

搭建Android測試環境:

1、下載AndroidSDK;

2、配置環境變量;

(1)、ANDROID_HOME

(2)、ANDROID_HOME-TOOLS

(3)、ANDROID_HOME-PALTFORM-TOOLS

3、Android底層Java開發,如需運行安卓遠程調試橋(adb),需Java運行環境;

4、下載JAVA;PS:下載JDK和JRE都行,JDK為JAVA開發環境,JRE為JAVA運行環境,開發環境中包含運行環境;

5、配置環境變量JAVA_HOME;

6、驗證Java -version;出現版本號即可

PS:Android手機如與windowS電腦連接需安裝手機驅動;Mac自動監測安裝

移動端性能測試指標:

1、啟動時間;(1)、冷啟動     (2)、熱啟動

冷啟動:應用的第一次啟動,這個時候應用程序的進程是沒有創建的

 熱啟動:應用非第一次啟動,如果按back鍵,並沒有將應用進程殺掉,熱啟動沒有了初始化的過程

adb命令:adb shell am start -W  mainActivity        可以看到ThisTime    TotalTime    WaitTime

ThisTime表示一連串啟動Activity的最后一個Activity的啟動耗時;

TotalTime表示新應用啟動的耗時,包括新進程的啟動和Activity的啟動,但不包括前一個應用Activity pause的耗時;

WaitTime就是總的耗時,包括前一個應用Activity pause的時間和新應用啟動的時間;

最后總結一下,如果只關心某個應用自身啟動耗時,參考TotalTime;如果關心系統啟動應用耗時,參考WaitTime;如果關心應用有界面Activity啟動耗時,參考ThisTime

PS:am全名activity manager,你能使用am去模擬更重系統的行為

       pm全名package manager,你能使用pm命令去模擬Android行為或查詢設備上的應用等,當你在adb shell 命令下執行pm命令

   

2、CPU占用率;

adb命令:adb shell top | grep pid

              adb shell top | grep package

     adb shell dumpsys cpuinfo | grep pid

     adb shell dumpsys cpuinfo | grep package     

PS: 最好先adb shell 進入安卓系統,在執行adb shell之后的語句  windows系統dos窗口中grep換成find

3、內存占用率;

adb命令:adb shell dumpsys meminfo | grep pid

           adb shell dumpsys meminfo | grep package

PS: 最好先adb shell 進入安卓系統,在執行adb shell之后的語句。  windows系統dos窗口中grep換成find

  TOTAL行的數據作為當前app內測占用的衡量數據;

執行出現結果會看到USS、RSS、VSS、PSS

USS指進程對子占用物理內存(不包含共享庫占用的內存);

RSS指實際使用的物理內存(包含共享庫占用的內存);

VSS指虛擬好用內存;

PSS指實際使用的物理內存;

PS:移動端采用PSS指標

4、耗電量;

adb命令:adb shell dumpsys battery

PS: 最好先adb shell 進入安卓系統,在執行adb shell之后的語句

出現信息解讀:

AC powered:false  是否連接AC(電源)充電線

USB powered:true  是否連接USB(PC或筆記本USB插口)充電

Wireless powered:false  是否使用了無線電源

status: 1    電池狀態,2為充電狀態,其他為非充電狀態

level:58     電量(%)

scale: 100.        電量最大數值

voltage: 3977      當前電壓(mV)

current now: -335232.     當前電流(mA)

temperature:355      電池溫度,單位為0.1攝氏度

technology:Li-poly.    電池種類

5、溫度;

cat /etc/thermald.conf

cat 為查看命令

6、每秒幀數(流暢度)[fps];

adb命令:adb shell dumpsys gfxinfo package

PS: 最好先adb shell 進入安卓系統,在執行adb shell之后的語句

     正常情況下幀率應該在16ms左右,如果1秒60幀的話,而且Execute時間太長!需要優化

7、GPU占用率;

PS :游戲會測試到,但一般不去測試該指標;

8、網絡;

(1)、Wi-Fi[網絡友好度]

(2)、蜂窩[耗費資源和友好度]

adb 命令:adb shell dumpsys package | grep userId         [通過app包名,獲取app的userID(安裝后唯一且固定)]

               adb shell cat /proc/uid_stat/userId/tcp_rcv      [cat為查看命令,讀取tcp_rcv獲取下載應用流量信息(設備重啟后清零)]

       adb shell cat /proc/uid_stat/userId/tcp_snd     [cat為查看命令,讀取tcp_snd獲取下載應用流量信息(設備重啟后清零)]

9、ANR(頁面無響應);

10、Crash(程序崩潰);

PS :ANR和Crash使用Monkey測試

注:dumpsys是Android手機里面的可執行文件

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM