踩坑記錄之前臺服務(wù)導(dǎo)致ANR

谷歌在安卓12以及以后的系統(tǒng),對應(yīng)用啟動服務(wù)進(jìn)行了更嚴(yán)格的限制,如果需要應(yīng)用在后臺停留的時候缰犁,仍然能夠執(zhí)行后臺代碼邏輯,這個時候需要通過前臺服務(wù)的機制怖糊,前臺服務(wù)和一般的服務(wù)API有兩處不同帅容,1是啟動服務(wù)的時候需要使用startForegroundService啟動服務(wù),其次是在前臺服務(wù)啟動之后必須要在5s內(nèi)調(diào)用startForeground,否則會導(dǎo)致ANR或者崩潰

前臺服務(wù)有什么限制伍伤?

  1. 安卓12之后并徘,在后臺啟動前臺服務(wù)可能會導(dǎo)致應(yīng)用崩潰,除非滿足某些豁免條件
  2. 服務(wù)的startForeground方法可能會崩潰扰魂,需要try catch
  3. 不要給startForeground傳入一個無效的通知id,可能會導(dǎo)致前臺服務(wù)拉起失敗
  4. 調(diào)用了stopForeground之后ams不再認(rèn)為當(dāng)前服務(wù)是前臺服務(wù)麦乞,這個時候我們可以通過startForeground重新讓當(dāng)前服務(wù)變成前臺服務(wù)(前提是服務(wù)沒有被殺死&并且如果在后臺的時候滿足相關(guān)豁免條件),否則startForeground的調(diào)用會發(fā)生崩潰

什么時候會導(dǎo)致ANR?

用戶startForegroundService蕴茴,5s內(nèi)沒有調(diào)用startForeground,并且沒有殺死服務(wù),那么5s后會看到anr

什么時候會崩潰

用戶startForegroundService姐直,在startForeground還沒有調(diào)用前倦淀,調(diào)用了stopService或者stopSelf殺死了服務(wù),這個時候多半會看到ForegroundServiceDidNotStartInTimeException這個異常

通常來說,當(dāng)我們?nèi)シ治鼍€上的ANR的情況的時候声畏,我們會傾向于主線程發(fā)生了耗時操作撞叽,前臺服務(wù)導(dǎo)致的ANR這一點可能會被忽略,因為前臺服務(wù)導(dǎo)致的ANR,日志上報的情況往往展示當(dāng)前主線程是空閑的!! 用傳統(tǒng)思路去解決anr可能無法切中要害

如何規(guī)避前臺服務(wù)相關(guān)的ANR和崩潰

方法一

在服務(wù)onCreate 以及onStartCommand最開始的調(diào)用中就調(diào)用startForeground

方法二(推薦)

前臺服務(wù)僅用作辈辶洌活愿棋,只在onCreate中調(diào)用一次startForeground,后續(xù)所有對服務(wù)的使用通過服務(wù)的Binder機制直接使用接口調(diào)用,如果服務(wù)和應(yīng)用程序在同一個進(jìn)程中均牢,也可以通過服務(wù)在onCreate的時候往一個全局的單例注冊一個接口糠雨,服務(wù)銷毀的時候接注冊該接口,也就是自己”模擬下“服務(wù)Bind的過程

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末徘跪,一起剝皮案震驚了整個濱河市甘邀,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌真椿,老刑警劉巖鹃答,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乎澄,死亡現(xiàn)場離奇詭異突硝,居然都是意外死亡,警方通過查閱死者的電腦和手機置济,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門解恰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人浙于,你說我怎么就攤上這事护盈。” “怎么了羞酗?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵腐宋,是天一觀的道長。 經(jīng)常有香客問我檀轨,道長胸竞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任参萄,我火速辦了婚禮卫枝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘讹挎。我一直安慰自己校赤,他們只是感情好吆玖,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著马篮,像睡著了一般沾乘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上浑测,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天意鲸,我揣著相機與錄音,去河邊找鬼尽爆。 笑死怎顾,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的漱贱。 我是一名探鬼主播槐雾,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼幅狮!你這毒婦竟也來了募强?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤崇摄,失蹤者是張志新(化名)和其女友劉穎擎值,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體逐抑,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡鸠儿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了厕氨。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片进每。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖命斧,靈堂內(nèi)的尸體忽然破棺而出田晚,到底是詐尸還是另有隱情,我是刑警寧澤国葬,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布贤徒,位于F島的核電站,受9級特大地震影響汇四,放射性物質(zhì)發(fā)生泄漏接奈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一船殉、第九天 我趴在偏房一處隱蔽的房頂上張望鲫趁。 院中可真熱鬧,春花似錦利虫、人聲如沸挨厚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽疫剃。三九已至钉疫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間巢价,已是汗流浹背牲阁。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留壤躲,地道東北人城菊。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像碉克,于是被迫代替她去往敵國和親凌唬。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355

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