【android开发-15】android中广播broadcast用法详解

news2024/12/22 23:18:05

1,broadcast类型

在Android中,Broadcast是一种用于在应用程序组件之间传递消息的机制。它允许一个组件(发送者)将消息发送给其他组件(接收者),即使它们之间不存在直接的联系。

Android中的Broadcast类型主要有以下几种:

1,普通广播(Ordinary Broadcast):这是默认类型的广播。当一个应用程序组件发送广播时,所有注册的广播接收器都会收到该广播。这种广播不会对接收者的数量进行限制。
在这里插入图片描述

2,有序广播(Ordered Broadcast):这是一种特殊的广播类型,可以按照接收者的优先级顺序逐个传递广播。发送者可以设置广播的优先级,并指定一组广播接收器按照优先级顺序接收广播。当一个接收者处理完广播后,广播会继续传递给下一个接收者。
在这里插入图片描述

3,系统广播(System Broadcast):系统广播是由操作系统或系统应用程序发送的广播。这些广播通常用于通知系统级别的操作,例如电量不足、内存不足等。应用程序可以注册系统广播的接收器来监听这些事件,并根据需要执行相应的操作。

4,粘性广播(Sticky Broadcast):这是一种特殊的系统广播类型,用于在一段时间内保持广播的传递。当一个粘性广播发送时,如果当前没有注册的接收器,则会在一段时间内保持传递,直到有接收器注册并接收该广播。这种广播通常用于需要持续通知的情境,例如网络连接变化等。

这些不同类型的广播可以根据需要选择使用,以满足不同的通信需求。

2,动态注册broadcast

在Android中,动态注册广播(Broadcast)需要遵循以下步骤:
1,创建BroadcastReceiver类:首先,你需要创建一个BroadcastReceiver类,该类将用于接收广播并处理接收到的广播数据。你可以在该类中重写onReceive()方法,该方法在接收到广播时被调用。

public class MyBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        // 处理接收到广播的逻辑  
        // 可以在这里根据intent的内容进行相应的处理  
    }  
}

2,实例化BroadcastReceiver:在你的应用程序中,你需要创建一个BroadcastReceiver的实例,以便能够接收广播。

MyBroadcastReceiver myBroadcastReceiver = new MyBroadcastReceiver();

3,创建IntentFilter:创建一个IntentFilter对象,该对象用于指定你想要接收的广播的Action。例如,如果你想要接收网络连接变化(CONNECTIVITY_CHANGE)的广播,你可以使用以下代码:

IntentFilter filter = new IntentFilter();  
filter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); // 以网络变化为例

4,注册BroadcastReceiver:使用registerReceiver()方法来注册BroadcastReceiver。你需要传递一个BroadcastReceiver对象和一个IntentFilter对象作为参数。注册后,你的BroadcastReceiver将会接收到指定Action的广播。

registerReceiver(myBroadcastReceiver, filter);

5,注销BroadcastReceiver:当你的应用程序不再需要接收广播时,你需要使用unregisterReceiver()方法注销BroadcastReceiver。这是为了避免内存泄漏。例如,你可以在Activity的onDestroy()方法中注销BroadcastReceiver:

unregisterReceiver(myBroadcastReceiver);

通过以上步骤,你可以在Android应用程序中动态注册并接收广播。请注意,动态注册的BroadcastReceiver只会在应用程序运行期间有效,当应用程序退出或用户切换到其他应用程序时,该Receiver会被注销。如果需要持续接收广播,可以考虑使用静态注册方式。

6,完整的动态注册参考代码:
在Android中,你可以使用registerReceiver()方法来动态注册一个BroadcastReceiver。以下是一个示例:

首先,定义一个BroadcastReceiver类:

public class MyBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        // 处理接收到广播的逻辑  
        // 可以在这里根据intent的内容进行相应的处理  
    }  
}

然后在你的Activity或Service中动态注册广播:

public class MyActivity extends AppCompatActivity {  
  
    private MyBroadcastReceiver myBroadcastReceiver;  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
  
        // 实例化BroadcastReceiver  
        myBroadcastReceiver = new MyBroadcastReceiver();  
  
        // 注册广播  
        IntentFilter filter = new IntentFilter();  
        filter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); // 以网络变化为例  
        registerReceiver(myBroadcastReceiver, filter);  
    }  
  
    @Override  
    protected void onDestroy() {  
        super.onDestroy();  
        // 在Activity销毁时,需要解注册广播,避免内存泄漏  
        unregisterReceiver(myBroadcastReceiver);  
    }  
}

以上代码会在Activity的onCreate方法中注册了一个名为"android.net.conn.CONNECTIVITY_CHANGE"的广播,当网络连接发生变化时,系统会发出这个广播,我们的MyBroadcastReceiver会接收到这个广播并在onReceive()方法中进行处理。同时,在Activity的onDestroy()方法中,我们通过unregisterReceiver()解注册了广播接收器,避免内存泄漏。

3,静态注册broadcast
在Android中,静态注册广播(BroadcastReceiver)需要将接收器(BroadcastReceiver)在应用程序的 AndroidManifest.xml 文件中进行声明,无需在运行时注册。以下是一个静态注册广播的示例代码:

1,在 AndroidManifest.xml 文件中添加 标签,指定要接收的广播的 Action 和与之关联的 BroadcastReceiver 类。例如,以下代码将注册一个 BroadcastReceiver,以接收网络连接变化(CONNECTIVITY_CHANGE)的广播:

<manifest ... >  
    <application ... >  
        <receiver android:name=".MyBroadcastReceiver" >  
            <intent-filter>  
                <action android:name="android.net.conn.CONNECTIVITY_CHANGE" />  
            </intent-filter>  
        </receiver>  
        ...  
    </application>  
</manifest>
```,2,在你的应用程序代码中定义 MyBroadcastReceiver 类,并实现 onReceive() 方法来处理接收到的广播数据。例如:

```cpp
public class MyBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        // 处理接收到广播的逻辑  
        // 可以在这里根据 intent 的内容进行相应的处理  
    }  
}

当网络连接发生变化时,系统会发出 “android.net.conn.CONNECTIVITY_CHANGE” 广播,你的应用程序中的 MyBroadcastReceiver 类将会接收到该广播并在 onReceive() 方法中进行处理。

注意:在程序未运行的情况下就可以接收到广播。

4,发送自定义广播
在Android中,你可以通过发送自定义的广播来传递自定义的数据。以下是一个示例,演示了如何发送和接收一个自定义广播:

1,创建一个自定义的广播Intent:

public class CustomBroadcastIntent {  
    public static final String CUSTOM_ACTION = "com.example.app.CUSTOM_ACTION";  
}

2,在发送广播的代码中,创建一个新的Intent对象,设置其Action为自定义Action,并添加需要传递的数据。然后使用sendBroadcast()方法发送广播。

Intent intent = new Intent();  
intent.setAction(CustomBroadcastIntent.CUSTOM_ACTION);  
intent.putExtra("custom_data", "This is custom data");  
sendBroadcast(intent);

sendBroadcast是Context的方法。

3,创建一个BroadcastReceiver类,用于接收自定义广播并处理接收到的数据。在该类中,你需要重写onReceive()方法,并在该方法中处理接收到的广播数据。

public class CustomBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        if (intent != null && intent.getAction().equals(CustomBroadcastIntent.CUSTOM_ACTION)) {  
            String customData = intent.getStringExtra("custom_data");  
            // 处理接收到的自定义数据  
        }  
    }  
}

4,在AndroidManifest.xml文件中注册BroadcastReceiver,以便应用程序能够接收到自定义广播。

<manifest ... >  
    <application ... >  
        <receiver android:name=".CustomBroadcastReceiver" >  
            <intent-filter>  
                <action android:name="com.example.app.CUSTOM_ACTION" />  
            </intent-filter>  
        </receiver>  
        ...  
    </application>  
</manifest>

现在,当发送广播的代码被执行时,自定义广播将被发送到注册了相应Action的BroadcastReceiver。在BroadcastReceiver的onReceive()方法中,你可以获取到自定义的数据并进行处理。

5,发送有序广播
在Android中,你可以使用sendOrderedBroadcast()方法来发送有序广播。有序广播的接收器会按照优先级顺序进行回调。如果某个接收器返回true,则传递会停止,不会传递给其他接收器。下面是一个发送有序广播的参考代码例子:

// 创建一个广播Intent  
Intent intent = new Intent(this, MyBroadcastReceiver.class);  
// 添加一个附加数据  
intent.putExtra("extra_data", "This is extra data");  
// 发送有序广播  
sendOrderedBroadcast(intent, null);

在这个例子中,MyBroadcastReceiver是你自己定义的BroadcastReceiver类。你可以在该类中重写onReceive()方法来处理接收到的广播数据。在这个例子中,我们向广播Intent添加了一个附加数据,可以在接收到广播时从Intent中获取到这个数据。

你可以在onReceive()方法中根据需要处理接收到的广播数据。如果你需要让广播继续传递给其他接收器,可以返回false,否则返回true来停止广播的传递。

public class MyBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        // 处理接收到的广播数据  
        String extraData = intent.getStringExtra("extra_data");  
        // 继续传递广播给其他接收器  
        boolean result = false; // 可以根据需要修改这个值  
        abortBroadcast(); // 停止广播的传递  
    }  
}

在这个例子中,我们在onReceive()方法中获取了附加数据,并返回了false来继续传递广播给其他接收器。如果你不想让广播继续传递,可以将result变量设置为true并调用abortBroadcast()方法来停止广播的传递。

如何设置有序广播的优先级?
在Android中,你可以通过在BroadcastReceiver的AndroidManifest.xml文件中设置android:priority属性来设置有序广播的优先级。优先级值越高,广播接收器的优先级就越高。当广播被发送时,系统会按照优先级顺序回调广播接收器。

以下是一个示例,展示了如何在AndroidManifest.xml中设置BroadcastReceiver的优先级:

<receiver android:name=".MyBroadcastReceiver" android:priority="100">  
    <intent-filter>  
        <action android:name="com.example.app.MY_ACTION" />  
    </intent-filter>  
</receiver>

在这个示例中,MyBroadcastReceiver的优先级被设置为100。如果其他BroadcastReceiver也有监听相同的Action,那么它们的优先级会低于MyBroadcastReceiver。你可以根据需要设置不同的优先级值。

需要注意的是,虽然可以通过设置优先级来控制广播的传递顺序,但建议谨慎使用,以避免滥用导致系统性能问题。在大多数情况下,最好使用普通广播而不是有序广播。

6,使用本地广播

在 Android 中,你可以使用本地广播(Local Broadcasts)来发送和接收广播消息。本地广播是一种仅限于当前应用程序的广播机制,它不会像全局广播一样广播到整个系统。下面是一个使用本地广播的参考代码例子:

LocalBroadcastManager 是 Android 中用于处理本地广播的类。它可以帮助你在应用程序内部更安全地发送和接收广播。下面是一个使用 LocalBroadcastManager 的参考例子:

1,创建一个广播类,例如 MyBroadcast:

public class MyBroadcast {  
    public static final String ACTION_NAME = "com.example.MY_ACTION";  
    public static final String EXTRA_MESSAGE = "message";  
}

2,创建一个广播接收器类,例如 MyBroadcastReceiver:

import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
import androidx.swiperefresh.widget.SwipeRefreshLayout;  
import android.util.Log;  
  
public class MyBroadcastReceiver extends BroadcastReceiver {  
    @Override  
    public void onReceive(Context context, Intent intent) {  
        String message = intent.getStringExtra(MyBroadcast.ExtraMessage);  
        Log.d("MyBroadcastReceiver", "Received message: " + message);  
        // 在这里处理接收到广播的逻辑  
    }  
}

3,在你的 Activity 或 Fragment 中使用 LocalBroadcastManager 发送广播:

import androidx.localbroadcastmanager.content.LocalBroadcastManager;  
import androidx.swiperefresh.widget.SwipeRefreshLayout;  
import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
import android.os.Bundle;  
import androidx.appcompat.app.AppCompatActivity;  
import android.view.View;  
import android.widget.Button;  
  
public class MainActivity extends AppCompatActivity {  
    private static final String TAG = "MainActivity";  
    private LocalBroadcastManager localBroadcastManager;  
    private MyBroadcastReceiver myBroadcastReceiver;  
   
    private Button sendBroadcastButton;  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
 
        localBroadcastManager = LocalBroadcastManager.getInstance(this);  
        myBroadcastReceiver = new MyBroadcastReceiver();  
        sendBroadcastButton.setOnClickListener(new View.OnClickListener() {  
            @Override  
            public void onClick(View v) {  
                localBroadcastManager.sendBroadcast();  
            }  
        });  
        // 注册广播  
        IntentFilter filter = new IntentFilter();  
        filter.addAction("android.net.conn.CONNECTIVITY_CHANGE"); // 以网络变化为例  
        localBroadcastManager.registerReceiver(myBroadcastReceiver, filter); 
    }  
}

注意:本地广播无法通过静态方式注册来接收广播。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1289521.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PMCW体制雷达系列文章(3) – PMCW雷达之匹配滤波

说明 PMCW体制下&#xff0c;雷达在接收端对接收的目标回波信号使用单频载波混频并低通滤波后&#xff0c;采集得到的是调制速率达ns量级的相位编码信号。在信号处理端&#xff0c;PMCW体制使用匹配滤波器(match filter)进行距离维的压缩&#xff0c;这是与FMCW体制雷达最核心的…

12 月版的 Java Annotated Monthly

本心、输入输出、结果 文章目录 12 月版的 Java Annotated Monthly前言Java 新闻使用 Gatherers 实现更好的 Java 流 – Inside Java Newscast #57Java 21 的新功能GPU 上的 Java 以下是本月针对 JDK 22 的新 JEP 候选者和 JEP 列表Java 教程和技巧框架、库相关花有重开日&…

java中 list.size() = 1 但显示 All elements are null

一、问题描述 serve层定义一个对象集合接收mybatis返回的结果&#xff0c;查询结果为空&#xff0c;但是接收集合对象长度却为1&#xff0c;集合内部显示All elements are null&#xff1b;导致在直接调用list集合中一些方法时导致报错java.lang.NullPointerException: null …

天池SQL训练营(三)-复杂查询方法-视图、子查询、函数等

-天池龙珠计划SQL训练营 SQL训练营页面地址&#xff1a;https://tianchi.aliyun.com/specials/promotion/aicampsql 3.1 视图 我们先来看一个查询语句&#xff08;仅做示例&#xff0c;未提供相关数据&#xff09; SELECT stu_name FROM view_students_info;单从表面上看起来…

超级详细的 Docker Desktop 安装 Keycloak

一、Keycloak 简介 收先先來看一下Keycloak的基本資訊: 名稱: Keycloak開發使用的程式語言: Java公用: 單點登入驗證與授權工具許可協議: Apache License 2.0公開倉庫: https://github.com/keycloak/keycloak官方網站: https://www.keycloak.org撰寫當下最新版本: 15.0.2 (20…

Linux环境下安装Nginx

Nginx&#xff08;发音&#xff1a;engine-x&#xff09;是一个高性能的HTTP和反向代理服务器&#xff0c;也可以作为邮件代理服务器使用。它是由俄罗斯程序员Igor Sysoev开发的&#xff0c;并在2004年公开发布。Nginx是一个开源项目&#xff0c;可以在Linux、Unix、BSD和Windo…

java--成员内部类、静态内部类、局部内部类

1.内部类 ①是类中的五大成分之一(成员变量、成员方法、构造器、内部类、代码块)&#xff0c;如果一个类定义另外一个类的内部&#xff0c;这个类就是内部类。 ②场景&#xff1a;当一个类的内部&#xff0c;包含了一个完整的事物&#xff0c;且这个事务没必要单独设计时&…

我们为什么那么关注 Java 中的 String Template ,Java 21 特性

本心、输入输出、结果 文章目录 我们为什么那么关注 Java 中的 String Template &#xff0c;Java 21 特性前言String TemplateString Template 有什么好处字符串连接 – 一个常见但无趣且容易出错的任务jetbrains IDEA 2023.2 版本及以上对于 String Template 的支持字符串模板…

今年圣诞爆款已出现!GMV稳定超越十万美刀,“装饰赛道”的爆单机会先到先得!

据统计&#xff0c;TiktTok平台圣诞节标签的流量已达40亿&#xff0c;且仍持续上涨。 流量驱动商品交易&#xff0c;转动短期生意增收飞轮。 在商品端&#xff0c;具有圣诞元素的服装、美妆、装饰类等商品频频热卖&#xff0c;仅仅一个小小的圣诞装饰信封&#xff0c;就在一个…

力扣 Java 101.对称二叉树

给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,3,4,4,3] 输出&#xff1a;true 示例 2&#xff1a; 输入&#xff1a;root [1,2,2,null,3,null,3] 输出&#xff1a;false 提示&#xff1a; 树中节点数目在…

今天刷basic

一 在kali里边链接这个服务器 ssh -p 25199 rootnode4.buuoj.cn 然后回车 yes 输入密码123456 ls查看发现什么都没有&#xff0c;cd ..返回上一级目录 ls 发现有flag.txt 查看文件得到flag flag{477f20d3-acd3-46e1-b50a-633e58b769c7}

什么是 shell 脚本?

一、什么是 shell&#xff1f; Shell 是一个应用程序&#xff0c;它负责接收用户输入的命令&#xff0c;然后根据命令做出相应的动作&#xff0c; Shell 负责将应用层或者用户输入的命令传递给系统内核&#xff0c;由操作系统内核来完成相应的工作&#xff0c;然后将结果反馈给…

几何精度因子(Geometric Dilution Precision ,GDOP)

一、概念介绍 在卫星定位领域&#xff0c;精度衰减因子&#xff08;英语&#xff1a;Dilution of precision&#xff09;是一类衡量用户在进行GNSS测量时所具备的几何条件的定量指标&#xff0c;又简称为DOP值或精度因子。DOP值的大小取决各导航卫星在用户视场中的分布情况&am…

查收查引(通过文献检索开具论文收录或引用的检索证明)

开具论文收录证明的 专业术语为 查收查引&#xff0c;是高校图书馆、情报机构或信息服务机构提供的一项有偿服务。 因检索需要一定的时间&#xff0c;提交委托时请预留足够的检索时间。 一般需要提供&#xff1a;论文题目、作者、期刊名称、发表年代、卷期、页码。 目录 一、查…

逆向爬虫进阶实战:突破反爬虫机制,实现数据抓取

文章目录 一、引言二、逆向爬虫进阶技巧三、逆向爬虫进阶实战代码片段四、总结与展望好书推荐内容简介作者简介前言节选 一、引言 随着网络技术的发展&#xff0c;网站为了保护自己的数据和资源&#xff0c;纷纷采用了各种反爬虫机制。然而&#xff0c;逆向爬虫技术的出现&…

CSS进阶知识点3——定位装饰

一、回顾 网页常见布局方式&#xff1a;标准流、浮动和定位的相互配合。 1.1 标准流 a块级元素独占一行——>垂直布局 b行内元素/行内块元素&#xff08;一行显示多个&#xff09;——>水平布局 1.2 浮动 可以让原本垂直布局的块级元素变成水平布局 1.3 定位 1可以…

Python Collections库的高级功能详解

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com Python的collections库提供了一系列有用的数据类型&#xff0c;扩展了内建的数据类型&#xff0c;为开发者提供了更多高级功能。本文将深入探讨collections库的一些高级功能&#xff0c;通过详细的示例代码演示&…

Multidimensional Scaling(MDS多维缩放)算法及其应用

在这篇博客中&#xff0c;我将与大家分享在流形分析领域的一个非常重要的方法&#xff0c;即多维缩放MDS。整体来说&#xff0c;该方法提供了一种将内蕴距离映射到显性欧氏空间的计算&#xff0c;为非刚性形状分析提供了一种解决方案。当初就是因为读了Bronstein的相关工作【1】…

深信服技术认证“SCSA-S”划重点:XSS漏洞

为帮助大家更加系统化地学习网络安全知识&#xff0c;以及更高效地通过深信服安全服务认证工程师考核&#xff0c;深信服特别推出“SCSA-S认证备考秘笈”共十期内容&#xff0c;“考试重点”内容框架&#xff0c;帮助大家快速get重点知识~ 划重点来啦 *点击图片放大展示 深信服…

DOCBOX dynamiccontent.properties.xhtml RCE漏洞复现

0x01 产品简介 DOCBOX是一款具有恢复保证的文档管理系统,高效、快如闪电、防审核、简单,从模拟切换到数字并使用 DOCBOX 归档您的文档。 0x02 漏洞概述 DOCBOX电子文档管理系统4.2.0版本中dynamiccontent.properties.xhtml接口存在远程代码执行漏洞,未经身份认证的攻击者可…