一、分类
标准广播
是一种完全异步执行的广播,在广播发出后,所有的广播接收器几乎会在同一时刻接受到这条广播消息,没有任何顺序而言。这种广播效率比较高,但是无法被截断。
有序广播
是一种同步执行的广播,在广播发出后,同一时刻只会有一个广播接收器能够收到这条广播消息,当这个广播接收器中的逻辑执行完毕后,广播才会继续传递。显而易见,这类广播是有先后顺序的,优先级高的广播接收器就可以先收到广播消息,并且前边的广播接收器可以截断正在传递的广播。
二、动态注册接收系统广播
就以监听网络变化为例吧!
步骤
1、声明网络权限
<use-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
2、创建一个类NetworkChangeReceiver继承自BroadcastReceiver。
3、创建一个IntentFilter实例,并为其添加一个值为android.net.conn.CONNECTIVITY_CHANGE的action。
4、创建NetworkChangeReceiver的实例,然后调用registerReceiver()方法进行注册,同时传入NetworkChangeReceiver的实例和IntentFilter的实例。
5、最后不要忘记取消注册广播接收器(因为此广播接收器为动态注册的)。
代码
package com.henuajy.broadcasttest;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.support.v4.content.LocalBroadcastManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
private IntentFilter intentFilter;
private NetworkChangeReceiver netWorkChangeReceiver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
intentFilter = new IntentFilter();
intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
netWorkChangeReceiver = new NetworkChangeReceiver();
registerReceiver(netWorkChangeReceiver,intentFilter);
}
@Override
protected void onDestroy() {
super.onDestroy();
unregisterReceiver(netWorkChangeReceiver);
}
class NetworkChangeReceiver extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context,"network chages",Toast.LENGTH_SHORT).show();
}
}
}
三、静态注册接收系统广播
仍然以监听系统网络状态为例
步骤
1、新建一个类NetworkChangeReceiver,继承BroadcastReceiver并重写onReceive()方法;
package com.henuajy.notificationtest;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;
public class NetworkChangeReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
//网络状态发生变化的逻辑
}
}
2、在配置文件中的manifest标签下声明网络权限;
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
3、在配置文件中的application标签下添加receiver并添加action--“android.net.conn.CONNECTIVITY_CHANGE”;
<receiver
android:name=".NetworkStateReceiver"
android:enabled="true"
android:exported="true">
<intent-filter>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE"/>
</intent-filter>
</receiver>
注意
Android系统为了保护用户设备的安全和隐私,做了严格的规定:如果程序需要进行一些对用户来书比较敏感的操作,就必须在配置文件中声明权限才可以,否则程序会直接崩溃。比如这里访问系统的网络状态就是需要声明权限的。
小补充
如果想要判断网络状态是开启还是关闭,可用下列方法:
1、通过getSystemService()【由于是关于网络状态的,所以要传入参数Context.CONNECTIVITY_SERVICE】方法获取ConnectionManager类的实例manager;
2、通过调用manager的getActiveNetworkInfo()方法获取NetworkInfo类的实例info;
3、通过info的isAvailable()【返回bool值】方法判断网络是否可用。
ConnectionManager manager = (ConnectivityManager)getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo info = manager.getActiveNetworkInfo();
if(info!=null&&info.isAvailable()){
//网络可用的逻辑
}else{
//网络不可用的逻辑
}