2-AII--BroadcastReceiver有序广播
零、前言
先讲个场景小故事: 从前,有个小男孩捡到一颗漂亮的石头,他想去卖,价格1元。 男孩(Boy)大喊:"我有一个漂亮的石头,只卖1元",一个石匠买了这个石头。 石匠(Stonemason)大喊:"我有一个漂亮的石头,只卖1000元。"一个雕刻家买了这个石头。 雕刻家(Graver)大喊:"我有一个漂亮的石头,只卖10w元。"一个宝石家买了这个石头。 宝石家(RubyMan)大喊:"我有一个漂亮的石头,只卖1000w元。"收藏家买了这个石头。 收藏家(Collector)不喊了,静静地收藏起来。男孩用一元买了一个棒棒糖,开心地吃着。故事结束。 按照这个顺序,只要某个人不喊了,任何一个环节都可以被打断,而导致石头的价格出现差异。这就是有序广播的作用。
二、广播接收者代码实现
1.男孩广播接收者:BR1_Boy.java
public class BR1_Boy extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //[1]获取到发送广播携带的数据 String content = getResultData(); //[2]展示到Toast上 Toast.makeText(context, "男孩:" + content, Toast.LENGTH_LONG).show(); // [2.1]终止广播 // abortBroadcast(); //[3]传递数据 setResultData("我有一个漂亮的石头,只卖1000元"); } }
2.石匠广播接收者:BR2_Stonemason.java
public class BR2_Stonemason extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //[1]获取到发送广播携带的数据 String content = getResultData(); //[2]展示到Toast上 Toast.makeText(context, "石匠:" + content, Toast.LENGTH_LONG).show(); // [2.1]终止广播 // abortBroadcast(); //[3]传递数据 setResultData("我有一个漂亮的石头,只卖10W元"); } }
3.雕刻家广播接收者:BR3_Graver.java
public class BR3_Graver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //[1]获取到发送广播携带的数据 String content = getResultData(); //[2]展示到Toast上 Toast.makeText(context, "雕刻家:" + content, Toast.LENGTH_LONG).show(); // [2.1]终止广播 // abortBroadcast(); //[3]传递数据 setResultData("我有一个漂亮的石头,只卖1000W元"); } }
4.宝石家广播接收者:BR4_RubyMan.java
public class BR4_RubyMan extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //[1]获取到发送广播携带的数据 String content = getResultData(); //[2]展示到Toast上 Toast.makeText(context, "宝石家:" + content, Toast.LENGTH_LONG).show(); // [2.1]终止广播 // abortBroadcast(); //[3]传递数据 setResultData("我有一个漂亮的石头,价值1000W元"); } }
5.收藏家广播接收者:BR5_Collector.java
/** * 最终的receiver 不需要再清单文件里面配置 */ public class BR5_Collector extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { String content = getResultData(); Toast.makeText(context, "收藏家:" + content, Toast.LENGTH_LONG).show(); } }
6.记得注册:app/src/main/AndroidManifest.xml
<receiver android:name=".stone.BR1_Boy"></receiver> <receiver android:name=".stone.BR2_Stonemason"></receiver> <receiver android:name=".stone.BR3_Graver"></receiver> <receiver android:name=".stone.BR4_RubyMan"></receiver>
三、测试代码实现:传播顺序按照注册顺序
1.StoneStoryActivity.java
public class StoneStoryActivity extends AppCompatActivity { @BindView(R.id.id_btn_send) Button mIdBtnSend; @BindView(R.id.id_btn_reg) Button mIdBtnReg; private BR1_Boy mBr1_boy; private BR2_Stonemason mBr2_stonemason; private BR3_Graver mBr3_graver; private BR4_RubyMan mBr4_rubyMan; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_story); ButterKnife.bind(this); } @OnClick({R.id.id_btn_send, R.id.id_btn_reg}) public void onViewClicked(View view) { switch (view.getId()) { case R.id.id_btn_send: Intent intent_order = new Intent(); intent_order.setAction("www.toly1994.com"); sendOrderedBroadcast(intent_order, null, new BR5_Collector(), null, 1, "我有一个漂亮的石头,只卖1元", null); break; case R.id.id_btn_reg://动态注册所有 IntentFilter filter = new IntentFilter(); filter.addAction("www.toly1994.com"); mBr1_boy = new BR1_Boy(); mBr2_stonemason = new BR2_Stonemason(); mBr3_graver = new BR3_Graver(); mBr4_rubyMan = new BR4_RubyMan(); registerReceiver(mBr1_boy, filter); registerReceiver(mBr2_stonemason, filter); registerReceiver(mBr3_graver, filter); registerReceiver(mBr4_rubyMan, filter); break; } } }
2.如果石匠截断,不喊了,直接卖给收藏家
public class BR2_Stonemason extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { //[1]获取到发送广播携带的数据 String content = getResultData(); //[2]展示到Toast上 Toast.makeText(context, "石匠:" + content, Toast.LENGTH_LONG).show(); // [2.1]终止广播 abortBroadcast(); //[3]传递数据 setResultData("我有一个漂亮的石头,价值1000元"); } }
附录、activity_story.xml
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".StoneStoryActivity"> <Button android:id="@+id/id_btn_send" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginStart="8dp" android:layout_marginTop="8dp" android:text="发送广播" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent"/> <Button android:id="@+id/id_btn_reg" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginStart="20dp" android:layout_marginTop="8dp" android:text="注册所有广播" app:layout_constraintBottom_toBottomOf="@+id/id_btn_send" app:layout_constraintStart_toEndOf="@+id/id_btn_send" app:layout_constraintTop_toTopOf="@+id/id_btn_send" app:layout_constraintVertical_bias="1.0"/> </android.support.constraint.ConstraintLayout>
后记、
1.声明:
[1]本文由张风捷特烈原创,转载请注明
[2]欢迎广大编程爱好者共同交流
[3]个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
[4]你的喜欢与支持将是我最大的动力
2.连接传送门:
更多安卓技术欢迎访问:安卓技术栈
我的github地址:欢迎star
简书首发,腾讯云+社区同步更新
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com
3.联系我
QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328
4.欢迎关注我的微信公众号,最新精彩文章,及时送达:
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
你知道Java的四种引用类型吗
从大一自学Java已经两年了,自觉已经可以独当一面,(其实远远不足),最近一直在看书。关于java四种引用类型,我也是刚了解,特此记下! 在Java中提供了四个级别的引用:强引用,软引用,弱引用和虚引用。在这四个引用类型中,只有强引用FinalReference类是包内可见,其他三种引用类型均为public,可以在应用程序中直接使用。引用类型的类结构如图所示。 1.强引用 Java中的引用,类似C语言中最难的指针。(我是C语言入门编程,指针的概念还是很深入我心。)通过引用,可以对堆中的对象进行操作。如: StringBuffer stringBuffer = new StringBuffer("Helloword"); 变量str指向StringBuffer实例所在的堆空间,通过str可以操作该对象。 强引用的特点: 强引用可以直接访问目标对象。 强引用所指向的对象在任何时候都不会被系统回收。JVM宁愿抛出OOM异常,也不会回收强引用所指向的对象。 强引用可能导致内存泄漏。 2.软引用 软引用是除了强引用外,最强的引用类型。可以通过java.lang.ref.SoftReference...
- 下一篇
Java获取虚拟机内存和操作系统内存及其线程
为什么要获取虚拟机内存和操作系统内存呢? 虚拟机内存,这里主要指JVM。为了防止有的时候因为JVM内存问题导致服务器宕机,所以有必要监控JVM的内存。当达到一定值时,通过邮件及时通知,防止线上宕机造成更大的损失。这里监控操作系统的内存同样如此。因为一个服务器上,tomcat,mysql,redis,mongodb,zabbix,nexus,jenkins,maven等等都是要占用操作系统的内存的。 特别是tomcat,mysql等等,线上每天都会产生大量的日志,而这些日志不能删。当然了,通过shell脚本可以定期对这些做备份。但是就拿我上家公司来说,一个服务器上,通常运行5到6个应用。这5到6个应用,虽说以crm和erp为主,对应网站性能和线程并发方面虽要求不高,但是它们在线上也会有大量日志输出,这些日志通常对于解决一些隐性Bug有很大的帮助,同时他们也会占用系统内存的。 关于邮件监控可以参考我的这篇文章:Spring定时任务使用和如何使用邮件监控服务器 另外在此也介绍下hutools这个开源项目,这个开源项目也提供与下面java代码一样的功能(系统属性调用) 参考地址为:http:/...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS关闭SELinux安全模块
- CentOS8编译安装MySQL8.0.19
- CentOS7设置SWAP分区,小内存服务器的救世主
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池