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条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS关闭SELinux安全模块
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- CentOS8编译安装MySQL8.0.19
- Windows10,CentOS7,CentOS8安装Nodejs环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS7,8上快速安装Gitea,搭建Git服务器

微信收款码
支付宝收款码