一、分类

标准广播
是一种完全异步执行的广播,在广播发出后,所有的广播接收器几乎会在同一时刻接受到这条广播消息,没有任何顺序而言。这种广播效率比较高,但是无法被截断。
有序广播
是一种同步执行的广播,在广播发出后,同一时刻只会有一个广播接收器能够收到这条广播消息,当这个广播接收器中的逻辑执行完毕后,广播才会继续传递。显而易见,这类广播是有先后顺序的,优先级高的广播接收器就可以先收到广播消息,并且前边的广播接收器可以截断正在传递的广播。

二、动态注册接收系统广播

就以监听网络变化为例吧!

步骤

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{
    //网络不可用的逻辑
}
05-14 12:22