九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
Android常用節(jié)點(diǎn)-CPU/GPU

Android性能測試(內(nèi)存、cpu、fps、流量、GPU、電量)——adb篇

adazone 2019-03-15 16:58:37  2380  收藏 12

分類專欄: android應(yīng)用層學(xué)習(xí)

adb 常用命令

獲取連接設(shè)備號(hào):adb devices

列出設(shè)備所有已安裝的包名 (不需root權(quán)限)
adb shell “pm list packages”,可以加上grep 進(jìn)行篩選(windows系統(tǒng)使用findstr /i “xxxx” 或者 find)

3)查看進(jìn)程列表:adb shell “ps”,同時(shí)也能獲取到應(yīng)用的UID,方式如下(不需root權(quán)限):

u0_a開頭的都是Android的應(yīng)用進(jìn)程,Android的應(yīng)用的UID是從10000開始,到19999結(jié)束,可以在Process.java中查看到(FIRST_APPLICATION_UID和LAST_APPLICATION_UID),u0_a后面的數(shù)字就是該應(yīng)用的UID值減去FIRST_APPLICATION_UID所得的值,所以,對于截圖這個(gè)應(yīng)用進(jìn)程,它是u0_a155,按前面的規(guī)制,它的UID就是155 + FIRST_APPLICATION_UID = 10155。
內(nèi)存說明
VSS - Virtual Set Size 虛擬耗用內(nèi)存(包含共享庫占用的內(nèi)存)
RSS - Resident Set Size 實(shí)際使用物理內(nèi)存(包含共享庫占用的內(nèi)存)
PSS - Proportional Set Size 實(shí)際使用的物理內(nèi)存(比例分配共享庫占用的內(nèi)存)
USS - Unique Set Size 進(jìn)程獨(dú)自占用的物理內(nèi)存(不包含共享庫占用的內(nèi)存)
一般來說內(nèi)存占用大小有如下規(guī)律:VSS >= RSS >= PSS >= USS
adb 查看單個(gè)內(nèi)存占用量 (均不需要root權(quán)限)

單個(gè)應(yīng)用的最大內(nèi)存限制

adb shell “getprop | grep heapgrowthlimit”

應(yīng)用啟動(dòng)后分配的初始內(nèi)存

adb shell “getprop|grep dalvik.vm.heapstartsize”

單個(gè)java虛擬機(jī)的最大內(nèi)存限制

adb shell “getprop|grep dalvik.vm.heapsize”

adb內(nèi)存數(shù)據(jù)采集
使用 adb shell "dumpsys meminfo -s <pakagename | pid>"命令,輸出結(jié)果分以下4部分:

process 以進(jìn)程的PSS從大到小依次排序顯示,每行顯示一個(gè)進(jìn)程;
OOM adjustment 分別顯示每類的進(jìn)程情況
category 以Dalvik/Native/.art mmap/.dex map等劃分的各類進(jìn)程的總PSS情況
total 總內(nèi)存、剩余內(nèi)存、可用內(nèi)存、其他內(nèi)存

執(zhí)行結(jié)果如下圖,重點(diǎn)取該應(yīng)用的TOTAL 對應(yīng)的內(nèi)存占用大?。↘B)

PS:在apk內(nèi)調(diào)用運(yùn)行獲取其他app的內(nèi)存數(shù)據(jù)則需要root權(quán)限
adb fps(每秒幀數(shù),計(jì)算流暢度)數(shù)據(jù)采集
adb命令:adb shell dumpsys gfxinfo <package | pid>
前提:開發(fā)者選項(xiàng)=>GPU呈現(xiàn)模式分析確保打開=>在adb shell dumpsys gfxinfo中or 在屏幕上顯示為線型圖
方法僅適用于Android原生應(yīng)用,不適用于游戲
正常情況下幀率應(yīng)該在16.67ms左右,1秒60幀,執(zhí)行結(jié)果如下:

gfxinfo

詳細(xì)計(jì)算方法如下:

首先獲取執(zhí)行一次命令打印出來的結(jié)果,重點(diǎn)關(guān)注Draw Prepare Process Execute 行下面的數(shù)據(jù)
Draw:是消耗在構(gòu)建java顯示列表DisplayList的時(shí)間。說白了就是執(zhí)行每一個(gè)View的onDraw方法,創(chuàng)建或者更新每一個(gè)View的DisplayList對象的時(shí)間。
Process:表示是消耗在Android的2D渲染器執(zhí)行顯示列表的時(shí)間,view越多,要執(zhí)行的繪圖命令就越多,時(shí)間就越長
Execute:消耗在排列每個(gè)發(fā)送過來的幀的順序的時(shí)間.或者說是CPU告訴GPU渲染一幀的時(shí)間,這是一個(gè)阻塞調(diào)用,因?yàn)镃PU會(huì)一直等待GPU發(fā)出接到命令的回復(fù)。所以這個(gè)時(shí)間,一般都很短。
Draw + Prepare+Process + Execute = 完整顯示一幀 ,這個(gè)時(shí)間要小于16ms才能保存每秒60幀。
計(jì)算總數(shù)據(jù)的行數(shù) frame_count = row_num, 計(jì)算每行渲染時(shí)間render_time = Draw + Prepare+Process + Execute, 當(dāng)渲染時(shí)間>16.67ms(1000/60),按照垂直同步機(jī)制,該幀已經(jīng)渲染超時(shí)
一旦render_time>16.67 算一次jank(丟幀),一旦jank,需要用掉額外的vsync
vsync_overtime = 向上取整(render_time/16.67) - 1
比如:render_time = 66.68 vsync_overtime = 3
render_time = 67 vsync_overtime = 4
一次命令執(zhí)行獲得的fps = int( frame_count * 60 / (frame_count + vsync_overtime_sum))

還有一個(gè)命令是: adb shell dumpsys SurfaceFlinger --latency LayerName
這個(gè)命令能獲取游戲/視頻應(yīng)用的fps數(shù)據(jù)
其中LayerName在各個(gè)不同系統(tǒng)中獲取的命令是不一樣的
在Android 6系統(tǒng)直接就是SurfaceView
在Android 7系統(tǒng)中可以通過 dumpsys window windows | grep mSurface | grep SurfaceView 然后通過數(shù)據(jù)截取到
在Android 8系統(tǒng)中可以通過 dumpsys SurfaceFlinger | grep android包名獲取到
執(zhí)行命令結(jié)果如下:

計(jì)算方法比較簡單,一般打印出來的數(shù)據(jù)是129行(部分機(jī)型打印兩次257行,但是第一部分是無效數(shù)據(jù),取后半部分),取len-2的第一列數(shù)據(jù)為end_time,取len-128的第一列數(shù)據(jù)為start_time
fps = 127/((end_time - start_time) / 1000000.0)
至于為啥要取第一列數(shù)據(jù),這里不做過多介紹,歡迎參看這兩篇文章
老羅的文章SurfaceView原理
Android性能測試之fps獲取
至于為啥要處于1000000,因?yàn)槊畲蛴〕鰜淼氖羌{秒單位,要轉(zhuǎn)為毫秒進(jìn)行計(jì)算,127就是因?yàn)槊钜淮未蛴〕鰜?27幀的數(shù)據(jù)而已
adb CPU占用率數(shù)據(jù)采集
有兩種方法可以獲取
1) adb shell “top -n 5 | grep <package | pid>” ,第三列就是實(shí)時(shí)監(jiān)控的CPU占用率(-n 指定執(zhí)行次數(shù),不需root權(quán)限),這邊top命令執(zhí)行需要2到3s左右,一般可以采用busybox 的top命令執(zhí)行,效率會(huì)快很多

2) adb shell “dumpsys cpuinfo | grep <package | pid>”
兩種方法直接區(qū)別在于,top是持續(xù)監(jiān)控狀態(tài),而dumpsys cpuinfo獲取的實(shí)時(shí)CPU占用率數(shù)據(jù)
adb 耗電量數(shù)據(jù)采集
adb命令:adb shell “dumpsys batterystats < package | pid>” (Android 5.0后引入)
獲取單個(gè)應(yīng)用的耗電量信息,具體返回結(jié)果待研究
adb命令:adb shell “dumpsys battery”
出現(xiàn)信息解讀:
AC powered:false 是否連接AC(電源)充電線
USB powered:true 是否連接USB(PC或筆記本USB插口)充電
Wireless powered:false 是否使用了無線電源
status: 1 電池狀態(tài),2為充電狀態(tài),其他為非充電狀態(tài)
level:58 電量(%)
scale: 100. 電量最大數(shù)值
voltage: 3977 當(dāng)前電壓(mV)
current now: -335232. 當(dāng)前電流(mA)
temperature:355 電池溫度,單位為0.1攝氏度

technology:Li-poly. 電池種類

adb 采集流量數(shù)據(jù)
adb 命令:adb shell “dumpsys< package | pid> | grep UID” [通過ps命令,獲取app的UID(安裝后唯一且固定)]
adb shell cat /proc/uid_stat/UID/tcp_rcv [cat為查看命令,讀取tcp_rcv獲取應(yīng)用接收流量信息(設(shè)備重啟后清零)]
adb shell cat /proc/uid_stat/UID/tcp_snd [cat為查看命令,讀取tcp_snd獲取應(yīng)用發(fā)送流量信息(設(shè)備重啟后清零)]
計(jì)算流量消耗步驟:

執(zhí)行一次這兩條命令,獲取到應(yīng)用的開始接收及發(fā)送的流量
然后我們再操作應(yīng)用,執(zhí)行一段時(shí)間測試
再次執(zhí)行上述 2 條命令可以獲取到應(yīng)用結(jié)束時(shí)候的接收及發(fā)送的流量,通過相減及得到應(yīng)用的整體流量消耗

或者還有一種方式獲取應(yīng)用流量消耗:

首先獲取應(yīng)用固定uid
dumsys package android包名 | grep userId

執(zhí)行cat /proc/net/xt_qtaguid/stats | grep uid

其中第6列代表rx_bytes接收的字節(jié)數(shù),第8列為tx_bytes發(fā)送的字節(jié)數(shù)
一個(gè)uid可能對應(yīng)多個(gè)進(jìn)程,把數(shù)據(jù)累加就行
兩個(gè)時(shí)間片中間應(yīng)用流量的消耗,就計(jì)算接收字節(jié)數(shù)的差值就行

adb采集CPU溫度
首先判斷類型:
cat /sys/class/thermal/thermal_zone*/type

只有紅框框出來的是有效的
cat /sys/class/thermal/thermal_zone*/temp
獲取CPU溫度

adb采集電池溫度
dumpsys battery | grep temperature 單位0.1攝氏度

adb采集整機(jī)CPU使用率和分核CPU使用率
獲取/proc/stat文件內(nèi)容(無權(quán)限限制)

總的cpu時(shí)間片是 total = user+nice+system+idle+iowait+irq+softirq
忙碌時(shí)間為 notidle = user+nice+system +iowait+irq+softirq
cpu使用率計(jì)算方法為,先取開始的total值和忙碌時(shí)間notidle,隔一段時(shí)間片,再取一次計(jì)算total2,notidle2, cpuuse = (notidle2 – notidle) * 100 / (total2 - total)%
PS:由于Android 8權(quán)限收緊,在Android 8系統(tǒng)手機(jī)內(nèi)apk內(nèi)讀取文件內(nèi)容為空,需要shell權(quán)限才可獲取文件內(nèi)容,下同
adb 采集各核cpu頻率
讀/sys/devices/system/cpu/cpuX/cpufreq/scaling_cur_freq文件的值,X不定,看是幾核手機(jī),scaling_cur_freq是否存在也不一定,需要判斷
至于為啥不取cpuinfo_cur_freq文件的值,原因是android 6,7系統(tǒng)獲取的時(shí)候,這個(gè)文件shell沒有讀取權(quán)限,需要root權(quán)限

參考文章:https://blog.csdn.net/long_zhimeng/article/details/45934899
adb獲取當(dāng)前運(yùn)行于手機(jī)前端的應(yīng)用的包名
Android 6,7系統(tǒng)可執(zhí)行
dumpsys window windows | grep “mCurrentFocus”
執(zhí)行結(jié)果一般為類似:
mCurrentFocus=Window{81caaa5 u0 com.tencent.mobileqq/com.tencent.mobileqq.activity.SplashActivity}
按照一定規(guī)則把com.tencent.mobileqq提取出來即可
adb 采集GPU占用率,目前支持高通GPU芯片(Qualcomm Adreno系列)
直接apk內(nèi)讀取文件即可,不需要shell權(quán)限(支持到Android8)
Gpu使用率獲取:會(huì)得到兩個(gè)值,(前一個(gè)/后一個(gè))*100%=使用率
adb shell cat /sys/class/kgsl/kgsl-3d0/gpubusy
Gpu工作頻率:
adb shell cat /sys/class/kgsl/kgsl-3d0/gpuclk
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/cur_freq
Gpu最大、最小工作頻率:
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/max_freq
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/min_freq
Gpu可用頻率
adb shell cat /sys/class/kgsl/kgsl-3d0/gpu_available_frequencies
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/available_frequencies
Gpu可用工作模式:
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/available_governors
Gpu當(dāng)前工作模式:
adb shell cat /sys/class/kgsl/kgsl-3d0/devfreq/governor
注意事項(xiàng)

所有dumpsys命令獲取性能數(shù)據(jù),如果adb shell進(jìn)入終端執(zhí)行,均要求執(zhí)行有shell權(quán)限,如果PC端進(jìn)入終端執(zhí)行,則無此要求

作者:某杰
鏈接:https://www.jianshu.com/p/6c0cfc25b038
來源:簡書
簡書著作權(quán)歸作者所有



Android常用節(jié)點(diǎn)-CPU/GPU

paulfuture 2020-03-31 18:22:38  184  收藏 1

文章標(biāo)簽: android cpu gpu

版權(quán)

CPU

  • /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq:CPU當(dāng)前頻率
    當(dāng)使用shell cat方式讀取了,CPU頻率會(huì)被瞬時(shí)拉升,導(dǎo)致讀取數(shù)值不準(zhǔn)確
    當(dāng)使用文件方式讀取時(shí),CPU頻率不會(huì)被瞬時(shí)拉升,讀取數(shù)值準(zhǔn)確

  • /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq:CPU最大頻率

  • /sys/devices/system/cpu/cpu0/cpufreq/scaling_min_freq:CPU最小頻率

GPU

  • /sys/class/kgsl/kgsl-3d0/gpu_model:GPU版本

  • /sys/class/kgsl/kgsl-3d0/gpu_busy_percentage:GPU使用率

  • /sys/class/kgsl/kgsl-3d0/idle_timer:GPU進(jìn)入idle模式的間隔長度,單位ms

  • /sys/class/kgsl/kgsl-3d0/min_pwrlevel:GPU最小頻率檔位

  • /sys/class/kgsl/kgsl-3d0/max_pwrlevel:GPU最大頻率檔位

  • /sys/class/kgsl/kgsl-3d0/devfreq/available_frequencies:GPU支持的頻率

  • /sys/class/kgsl/kgsl-3d0/devfreq/cur_freq:GPU當(dāng)前頻率

  • /sys/class/kgsl/kgsl-3d0/devfreq/available_governors:GPU支持的governor

  • /sys/class/kgsl/kgsl-3d0/devfreq/governor:GPU當(dāng)前governor

  • /sys/class/kgsl/kgsl-3d0/devfreq/min_freq:GPU最小頻率

  • /sys/class/kgsl/kgsl-3d0/devfreq/max_freq:GPU最大頻率

min_freq和max_freq在GPU suspended狀態(tài)下不可配置,需要通過運(yùn)行app或配置idle_timer節(jié)點(diǎn)進(jìn)行激活

Kernel

  • /dev/kmsg:持續(xù)log

  • /proc/kmsg:會(huì)中斷,斷開連接

Power

  • /sys/power/wake_lock

  • /sys/power/wake_unlock

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Android APP性能及專項(xiàng)測試(個(gè)人整理)
Android 開發(fā)者選項(xiàng)詳述
Android耗電量測試及排查方法
adb好用命令(自動(dòng)化測試過程中)
Android之a(chǎn)db shell dumpsys activity獲取task里面的所有actitiy
adb logcat 抓取日志
更多類似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服