電量與應(yīng)用程序
電能計(jì)算公式
電能 = 電壓 * 電流 * 時(shí)間
對(duì)于手機(jī)來(lái)說(shuō)電壓一般不會(huì)改變诚纸,所以最終模塊耗電情況計(jì)算公式為:
模塊電量(mAh)= 模塊電流(mA) * 模塊耗時(shí)(h)
Android系統(tǒng)要求不同的廠商必須在/frameworks/base/core/res/res/xml/power_profile.xml 中提供組件的電源配置文件。power_profile.xml文件定義了不同模塊的電流消耗值以及該模塊在一段時(shí)間內(nèi)大概消耗的電流仿荆。
Android系統(tǒng)的電量計(jì)算PowerProfile也是通過(guò)讀取power_frofile.xml的數(shù)據(jù),不同的廠商具體數(shù)據(jù)不太一樣,可以通過(guò)以下方法獲惹乱:
- 從手機(jī)中導(dǎo)出/system/framework/framework-res.apk文件
- 使用反編譯工具對(duì)導(dǎo)出的文件framework-res.apk進(jìn)行反編譯
- 查看power_profile.xml文件在framework-res.反編譯目錄路徑:/res/xml/power_profile.xml。
對(duì)于系統(tǒng)的耗電量情況助隧,可以通過(guò)dumpsys batterystats導(dǎo)出
adb shell dumpsys batterystats > battery.txt
adb shell dumpsys batterystats --reset
BatteryStatsService是對(duì)外的電量統(tǒng)計(jì)服務(wù)筑凫,但具體的統(tǒng)計(jì)工作是由BatteryStatsImpl來(lái)完成,而BatteryStatsImpl內(nèi)部使用的就是PowerProfile并村。BatteryStatsImpl會(huì)為每個(gè)應(yīng)用創(chuàng)建一個(gè)UID實(shí)例來(lái)監(jiān)控應(yīng)用的系統(tǒng)資源使用情況巍实,統(tǒng)計(jì)系統(tǒng)資源包括下面圖里的內(nèi)容。
Android 9.0之后嚴(yán)格的電源管理限制:
什么是耗電優(yōu)化
- 耗電優(yōu)化的的第一個(gè)方向是優(yōu)化后臺(tái)應(yīng)用的后臺(tái)耗電
- 耗電優(yōu)化的第二個(gè)方向是符合系統(tǒng)規(guī)則哩牍,讓系統(tǒng)認(rèn)為你的耗電是正常的
耗電優(yōu)化的難點(diǎn)
- 缺乏現(xiàn)場(chǎng)棚潦,無(wú)法復(fù)現(xiàn)
- 信息不全,難以定位
- 無(wú)法評(píng)估結(jié)果
耗電優(yōu)化的方法
浪費(fèi)電量的主要原因有:
- 某個(gè)需求場(chǎng)景強(qiáng)制要求
- 代碼bug
相反耗電優(yōu)化的解決方案就是: - 找到需求場(chǎng)景的替代方案
- 符合Android規(guī)則
- 異常情況監(jiān)控
耗電監(jiān)控
1膝昆、監(jiān)控內(nèi)容
- 監(jiān)控信息
- 現(xiàn)場(chǎng)信息
- 提煉規(guī)則
2丸边、如何監(jiān)控耗電
Java Hook
Hook方案的好處是使用者接入非常簡(jiǎn)單,不需要修改自己的代碼荚孵。通過(guò)Hook我們可以在申請(qǐng)資源的時(shí)候?qū)⒍褩P畔⒈4嫫饋?lái)妹窖,當(dāng)我們觸發(fā)某個(gè)規(guī)則上報(bào)問(wèn)題時(shí)候,可以將收集到的堆棧信息收叶、電池是否充電骄呼、CPU信息、應(yīng)用前后臺(tái)時(shí)間等輔助信息一起帶上
插樁
雖然使用Hook非常簡(jiǎn)單,但是某些規(guī)則可能不太容易找打合適的Hook點(diǎn)蜓萄,而且Android P之后隅茎,很多的Hook點(diǎn)都不支持了。Facebook也有一個(gè)耗電監(jiān)控的開(kāi)源庫(kù)Battery-Metrics嫉沽,它監(jiān)控的數(shù)據(jù)非常全辟犀,包括Alarm、WakeLock耻蛇、Camera踪蹬、CPU、Network等臣咖。而且也有收集電量充電狀態(tài)跃捣、電量水平等信息。
插樁方案使用起來(lái)兼容性非常好夺蛇,并且使用者也沒(méi)有太大的接入成本疚漆,但是它并不是完美無(wú)缺的,對(duì)于系統(tǒng)的代碼插樁方案是無(wú)法替換的刁赦。