Android3.1後Boot_COMPLETED廣播收不到的問題及解決辦法

   在做Android開發時,很多應用由於各種目的,希望在機器啓動時被喚醒,一般的做法是寫一個BroadcastReceiver,接收對應的boot action,當然別忘了在Manifest中添加permission "android.permission.RECEIVE_BOOT_COMPLETED“。但是最近在做4.0開發時,有同事聲稱這個廣播接收不到了,同時其他有人又說自己的能接收到,到底是怎麼回事呢。

    原來,在3.1之後,系統的package manager增加了對處於“stopped state”應用的管理,這個stopped和Activity生命週期中的stop狀態是完全兩碼事,指的是安裝後從來沒有啓動過和被用戶手動強制停止的應用,與此同時系統增加了2個Flag:FLAG_INCLUDE_STOPPED_PACKAGESFLAG_EXCLUDE_STOPPED_PACKAGES ,來標識一個intent是否激活處於“stopped state”的應用。當2個Flag都不設置或者都進行設置的時候,採用的是FLAG_INCLUDE_STOPPED_PACKAGES的效果。

    有了上面的新機制之後,google覺得給所有的廣播intent默認加上FLAG_EXCLUDE_STOPPED_PACKAGES會非常的Cooooool,能在一定程度上避免流氓軟件、病毒啊幹壞事,還能提高效率,就導致了本文題目中說的問題,RECEIVE_BOOT_COMPLETED廣播如果用戶沒有運行過應用,就不會響應了。

    不過google還是留了點餘地,允許應用和後臺服務通過給廣播intent設置FLAG_INCLUDE_STOPPED_PACKAGES來喚醒處於“stopped state”的程序,也就是用戶自己寫的廣播intent可以控制這個機制,但是系統自帶的廣播intent,由於不能修改,就只能接受這個現實了。

解決方案:定製系統,修改framework,把系統發bootcompleteIntent的地方改一下,在intent裏設上FLAG_EXCLUDE_STOPPED_PACKAGES,那樣在這個系統裏,你的APP就可以開機啓動了.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章