Android广播机制

本文深入解析Android中广播机制,包括标准广播、有序广播及本地广播的区别与实现方式,同时提供了动态注册与静态注册的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

广播类型
Android中,广播主要分为两种类型:标准广播和有序广播,

  1. 标准广播是一种完全一步执行的广播,在广播发出之后,所有的广播接收器几乎都会在同一时刻接收到这条广播消息,因此他们之间没有任何先后顺序可言.这种广播效率比较高,但是不能被截断.

  2. 有序广播是一种同步执行的广播,在广播发出之后,同一时刻只有一个广播接收器能够收到这条广播消息,当这个广播接收器中的逻辑执行完毕后,广播才会继续传递,所以优先级高的广播接收器可以先收到广播消息,并且前面的广播接受器可以截断正在传递的广播,后面的广播接收器就无法收到广播信息了.

    注册广播接收器
    广播接收器的注册分为两种,动态注册和静态注册:
    动态注册就是在代码中进行注册,静态注册就是在AndroidManifest.xml中注册

动态注册方法:新建一个类,继承自BroadcastReceiver,并重写父类的onReceive()方法,当有广播进来时,onReceive()方法就会得到执行,具体的逻辑就在这个方法中处理.

动态注册示例:

public class MainActivity extends Activity {
    private NetworkChangeReceiver networkChangeReceiver;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        IntentFilter intentFilter = new IntentFilter();
        intentFilter.addAction("android.net.conn.CONNECTIVITY_CHANGE");
        networkChangeReceiver = new NetworkChangeReceiver();
        registerReceiver(networkChangeReceiver, intentFilter); //注册广播接收
        Button button = (Button) findViewById(R.id.sendBroadcast);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent("org.superzhao.broadcast.mybroadcast");
                sendBroadcast(intent);//标准广播
                //sendOrderedBroadcast(intent,null);//有序广播
            }
        });



    @Override
    protected void onDestroy() { // 注册了广播接收,要记得销毁
        super.onDestroy();
        unregisterReceiver(networkChangeReceiver);
        localBroadcastManager.unregisterReceiver(localBroadcastReceive);
    }

    //接收是否有网络的广播内置类
    class NetworkChangeReceiver extends BroadcastReceiver{
        @Override
        public void onReceive(Context context, Intent intent) {
            //Toast.makeText(context,"network changed",Toast.LENGTH_SHORT).show();
            ConnectivityManager connectivityManage =
                    (ConnectivityManager) getSystemService(context.CONNECTIVITY_SERVICE);
            NetworkInfo networkInfo = connectivityManage.getActiveNetworkInfo();
            if(networkInfo!=null && networkInfo.isAvailable()){
                Toast.makeText(context,"network available",Toast.LENGTH_SHORT).show();
            }else{
                Toast.makeText(context,"network unavailable",Toast.LENGTH_SHORT).show();
            }
        }
    }

一定要记得动态注册的广播接收器一定要取消注册才行.onDestroy()中的代码就是取消注册的.

如果程序需要访问一些系统的关键性信息,必须在配置文件中声明权限才可以,否则程序将直接崩溃,这是Android中为了保证应用程序的安全性做的规定

在AndroidManifest.xml文件中添加<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>,代表允许应用程序拥有查看网络状态的权限

静态注册方法:

同样新建一个广播接收器类,然后在AndroidManifest.xml文件中添加

<receiver android:name=".MyBroadcast" >
            <intent-filter android:priority="50">
                <action android:name="org.superzhao.broadcast.mybroadcast">

                </action>
            </intent-filter>
        </receiver>

在 中通过android:name指定具体注册哪一个广播接收器,在 中指定要接收的广播的名称,

发送有序广播
发送有序广播就是像上面第一个代码那样,只不过sendBroadcast(intent)变成了sendOrderedBroadcast(intent,null)就可以发送有序广播了,有序广播中可以在 中使用android:priority=”50”设置接收广播的顺序,里面的数字越大优先级越高,有序广播也可以让先接收到广播的接收器截断广播,使它不向下传递,在优先接收的接收器的onReceive()方法中加入abortBroadcast() 这句代码就可以截断广播了.

使用本地广播
上面说的广播都是属于系统全局广播,也就是发出的广播可以被其他任何应用程序接收到,这样就容易引起安全性的问题,为了解决这个问题,Android引入了一套本地广播机制,使用这个机制发出的广播只能够在应用程序的内部进行传递,并且广播接收器也只能接收来自本应用程序发出的广播,这样安全心的问题就都不存在了.
本地广播示例:

public class MainActivity extends Activity {
    private LocalBroadcastManager localBroadcastManager;
    private LocalBroadcastReceive localBroadcastReceive;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //发送本地广播
        localBroadcastManager = LocalBroadcastManager.getInstance(this);
        localBroadcastReceive = new LocalBroadcastReceive();
        Button button1 = (Button)findViewById(R.id.sendLocalBroadcast);
        button1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent("org.superzhao.broadcast.myLocalBroadcast");
                localBroadcastManager.sendBroadcast(intent);
            }
        });
        localBroadcastManager.registerReceiver(localBroadcastReceive,intentFilter1);
    }

    @Override
    protected void onDestroy() { // 注册了广播接收,要记得销毁
        super.onDestroy();
        localBroadcastManager.unregisterReceiver(localBroadcastReceive);
    }


    //本地广播接收类
    class LocalBroadcastReceive extends BroadcastReceiver{

        @Override
        public void onReceive(Context context, Intent intent) {
            Toast.makeText(context,"localbroadcast receive",Toast.LENGTH_SHORT).show();
        }
    }

}

本地广播是无法通过静态注册的方式来接收的,其实这也完全可以理解,因为静态注册主要就是为了让程序在未启动的情况在也能接收到广播,而发送本地广播时,程序肯定已经启动了,因此不需要使用静态注册的功能.

总结本地广播的优势:

  1. 可明确知道正在发送的广播不会离开我们的程序,因此不需要担心机密数据泄漏的问题.
  2. 其他的程序无法将广播发送到我们程序的内部,因此不需要担心有安全漏洞的隐患.
  3. 发送本地广播比起发送系统广播将更加高效
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值