APP开发实战76-广播机制相关API重要变迁

从Android 5.0开始,粘滞广播和有序粘滞广播不再推荐使用。静态注册的广播接收器在Android 3.1之后若app退出,可能无法接收到广播,因为系统默认设置FLAG_EXCLUDE_STOPPED_PACKAGES,导致无法对已停止的包发送广播。但在自定义广播中,可通过复写flag来允许静态注册的接收器在进程退出后仍接收广播。Android 3.1前的静态注册广播策略不再适用,开发者可考虑使用服务与App进程分离的方式作为替代。
摘要由CSDN通过智能技术生成

(1)Android5.0/APIlevel 21开始粘滞广播和有序粘滞广播过期,以后不再建议使用;

(2)静态注册的广播接收器即使app已经退出,主要有相应的广播发出,依然可以接收到,但此种描述自Android 3.1开始有可能不再成立。

主要原因如下:

Android 3.1开始系统在Intent与广播相关的flag增加了参数,分别是

FLAG_INCLUDE_STOPPED_PACKAGES:包含已经停止的包(停止:即包所在的进程已经退出)

FLAG_EXCLUDE_STOPPED_PACKAGES:不包含已经停止的包

自Android3.1开始,系统本身则增加了对所有app当前是否处于运行状态的跟踪。在发送广播时,不管是什么广播类型,系统默认直接增加了值为FLAG_EXCLUDE_STOPPED_PACKAGES的flag,导致即使是静态注册的广播接收器,对于其所在进程已经退出的app,同样无法接收到广播。

(详情参加Android官方文档:

http://developer.android.com/about/versions/android-3.1.html#launchcontrols)

对于系统广播,由于是系统内部直接发出,无法更改此intent flag值,因此,Android3.1开始对于静态注册的接收系统广播的BroadcastReceiver,如果App进程已经退出,将不能接收到广播。

但是对于自定义的广播,可以通过复写此flag为FLAG_INCLUDE_STOPPED_PACKAGES,使得静态注册的BroadcastReceiver,即使所在App进程已经退出,也能能接收到广播,并会启动应用进程,但此时的BroadcastReceiver是重新新建的。

在Android3.1以前,不少App可能通过静态注册方式监听各种系统广播,以此进行一些业务上的处理(如即时App已经退出,仍然能接收到,可以启动service等..),Android3.1后,静态注册接受广播方式的改变,将直接导致此类方案不再可行。       

通过将Service与App本身设置成不同的进程已经成为实现此类需求的可行替代方案。

(转自; http://www.cnblogs.com/lwbqqyumidi/p/4168017.html) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值