概述
Android的广播有:
普通广播(Normal Broadcast)
有序广播(Ordered Broadcast)
粘性广播(Sticky Broadcast)
系统广播(System Broadcast)
本地广播(Local Broadcast)
介绍:
本次分析的是粘性广播(Sticky Broadcast),粘性广播是属于可拦截广播的。粘性广播通过Context.sendStickBroadcast()方法来发送,用此方法发送的广播会一直滞留,当有匹配此广播的接收器被注册后,该广播接收器就会收到此广播。
广播的整个过程一般分三步:
第一步:发送广播
第二步:注册广播
第三步:接收广播
补:第四步:注销广播接收器 (内容暂未写)//如果注册广播接收器的对象是短生命周期的不做该动作会导致内存泄漏和运行时错误。
第一步:发送广播
/*
*@param flags要设置的新标志。
*设置intent的Action属性,这个会使intent找到与之对应的广播接收器
*Intent(Staring action);里面做了setAction(action);设置
*/
final Intent intent = new Intent(Staring action);
intent.addFlags(int flags);
intent.putExtra("msgKey", "消息内容");//给Intent设置可传递的消息
mContext.sendstickyBroadcastAsUser(intent, UserHandle.ALL);//发送广播
/*实例1
final Intent intent = new Intent(WifiManager.WIFI_STATE_CHANGED_ACTION);
intent.addFlags(Intent.FLAG_RECEIVER_REGISTERED_ONLY_BEFORE_BOOT);
intent.putExtra(WifiManager.EXTRA_WIFI_STATE,newstate);//给Intent设置可传递的消息
mContext.sendstickyBroadcastAsUser(intent, UserHandle.ALL);//发送广播
*/
第二步:注册广播。
注册广播的用意其实就是把广播的发送端和接收端给联系起来,不注册的话就相当于我发送了广播,然后这个广播不知道发给了谁,谁来接收处理。等同于一部没有调台按钮的收音机一样,不进行调台就接收不到对应的信号。
那么注册广播的话分为两种,一种是静态注册,另一种是动态注册。这里根据我所看的源码分析是动态注册。
动态注册的方式有以下:
/*
*@param action要匹配的动作的名称,例如 WifiManager.WIFI_STATE_CHANGED_ACTION
*@param receiver用于处理广播的BroadcastReceiver。
*@param filter选择要接收的Intent广播。
*@param broadcastPermission广播器发送意图时必须持有的权限字符串。如果为空,则不需要权限。
*@param scheduler标识“将要接收Intent的线程”的处理程序。如果为空,将使用进程的主线程。
*/
IntentFilter filter = new IntentFilter();
filter.addAction (Staring action);//添加要匹配的action动作名称,与发送广播的action动作名称对应
registerReceiver(BroadcastReceiver receiver,IntentFilter filter,
@Nullable string broadcastPermission,
@Nullable Handler scheduler); //注册
/*实例2
IntentFilter filter = new IntentFilter();
filter.addAction (WifiManager.WIFI_STATE_CHANGED_ACTION);//添加要匹配的action动作名称,与发送广播的action动作名称对应
mContext.registerReceiver(mBroadcastReceiver, filter,
/* broadcastPermission *
/ null, mlorkerHandler);
*/
第三步:接收广播
上面第二步中的实例2中-->mContext.registerReceiver(mBroadcastReceiver, filter,/* broadcastPermission */ null, mlorkerHandler);,当接收到的广播满足filter里的匹配的action动作名称时,则执行mBroadcastReceiver,重写mBroadcastReceiver里的onReceive()方法。根据获取到的action做出对应的逻辑处理。
进到onReceive()方法后,可以看到其中的if (WifiManager.WIFI_STATE_CHANGED ACTION.equals(action)) {}判断条件跟第一步中的实例1的final Intent intent = new Intent(WifiManager.WIFI_STATE_CHANGED_ACTION);对应,这满足条件执行该if()语句里的操作。
private final BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() {
public void onReceive(Context context, Intent intent){
String action =intent.getAction();
if (WifiManager.WIFI_STATE_CHANGED_ACTION.equals(action)) { //这个action对应着第一步中实例1的intent = new Intent(WifiManager.WIFI_STATE_CHANGED_ACTION);,所以action的值为WifiManager.WIFI_STATE_CHANGED_ACTION,该if()语句条件比较 == 成立
if (WifiManager.getwifistate() == WifiManager. WIFI_STATE_ENABLED) {
mScanner.start();
}else{
mScanner.stop();
}
...
...
}
}
...
}
第四步:注销广播接收器 (内容暂未写)
如果注册广播接收器的对象是短生命周期的不做该动作会导致内存泄漏和运行时错误。
说白了就是广播接收器处理完广播之后长时间不使用不注销广播接收器的话,会导致内存泄漏和运行时错误
最后
以上就是无心画笔为你收集整理的【Android】粘性广播的发送、注册、接收,基于Android12.0的WiFi部分源码分析的全部内容,希望文章能够帮你解决【Android】粘性广播的发送、注册、接收,基于Android12.0的WiFi部分源码分析所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复