耗電優(yōu)化

電量與應(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ú)法替換的刁赦。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末娶聘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子甚脉,更是在濱河造成了極大的恐慌丸升,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牺氨,死亡現(xiàn)場(chǎng)離奇詭異狡耻,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)猴凹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門夷狰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人郊霎,你說(shuō)我怎么就攤上這事沼头。” “怎么了书劝?”我有些...
    開(kāi)封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵进倍,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我庄撮,道長(zhǎng)背捌,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任洞斯,我火速辦了婚禮毡庆,結(jié)果婚禮上坑赡,老公的妹妹穿的比我還像新娘。我一直安慰自己么抗,他們只是感情好毅否,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著蝇刀,像睡著了一般螟加。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上吞琐,一...
    開(kāi)封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天捆探,我揣著相機(jī)與錄音,去河邊找鬼站粟。 笑死黍图,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奴烙。 我是一名探鬼主播助被,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼切诀!你這毒婦竟也來(lái)了揩环?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤幅虑,失蹤者是張志新(化名)和其女友劉穎丰滑,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體倒庵,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吨枉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了哄芜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡柬唯,死狀恐怖认臊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情锄奢,我是刑警寧澤失晴,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站拘央,受9級(jí)特大地震影響涂屁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜灰伟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一拆又、第九天 我趴在偏房一處隱蔽的房頂上張望儒旬。 院中可真熱鬧,春花似錦帖族、人聲如沸栈源。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)甚垦。三九已至,卻和暖如春涣雕,著一層夾襖步出監(jiān)牢的瞬間艰亮,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工挣郭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留迄埃,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓丈屹,卻偏偏與公主長(zhǎng)得像调俘,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子旺垒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容