java.lang.Object

   ↳

android.content.BroadcastReceiver

已知直接子类

  • AppWidgetProvider
  • DeviceAdminReceiver,
  • WakefulBroadcastReceiver

类概述

基类代码会收到sendbroadcast()意图。
假设你不须要在应用程序发送广播,考虑使用localbroadcastmanager类取代下面描写叙述的更一般的设施。这会给你一个更有效的实现(没有跨进程通信的须要),相关的其他应用程序可以接收或发送你的广播。同意你避免思考不论什么安全问题。

你能够通过Context.registerReceiver() 动态注冊这一类的上下文的一个实例。或静态公布一个<receiver>标签在你的AndroidManifest.xml配置文件。


注意:
假设在Activity.onResume()动态注冊一个接收器,你应该在 Activity.onPause()取消它的活动。(暂停时你不会接受意图,这将降低不必要的系统开销)。

不要在Activity.onSaveInstanceState()取消活动。

由于这不会被称为是用户在历史堆向后移动。


广播能够接收两大类

  1. 正常广播( Context.sendBroadcast发送)是全然异步的。全部的广播接收者是执行在一个不确定的顺序。往往在同一时间。这是更有效的,但意味着接收机无法使用的结果或中止API包括在这里。
  2. 有序广播(Context.sendOrderedBroadcast发送)被传递到一个接收器在时间。因为每一个接收器执行反过来,它能够传播的结果到下一个接收器,或全然放弃广播这样不会被传递到其它的接收机。

    命令接收器能够执行在android:priority :匹配的意图过滤器优先级属性。具有同样优先级的接收器将执行在一个随意的顺序

即使在正常广播的情况下,系统可能在某些情况下,恢复一次传送广播接收机。特别是。接收器。可能须要一个创造的过程。仅仅有一个将执行在一个时间来避免超载的系统的新工艺。

然而在这样的情况下,非顺序的语义,觉得:这些接收器还不能返回的结果或中止其广播。请注意。虽然意图类用于发送和接收这些广播,广播机构的意图是从这里的意图是用来启动活动中全然分离 Context.startActivity()。没有办法让中看到或捕获用于startactivity()意图;相同。当你广播的意图,你将永远找不到或启动活动。这两个操作在语义上是很不同的:从一个意向活动是一个前台操作,改动什么用户当前交互;广播意图是后台操作,用户通常不知道。

BroadcastReceiver类(启动时作为一个组件通过一个明显的 <receiver>标签)是一个应用程序的整个生命周期的一个重要组成部分。


主题

了解怎样使用这个类来接收和解决的意图。阅读Intents
and Intent Filters
开发人员指南。

  1. 安全保障

    1. 接收器使用的Context API本身就是一种跨应用设施,所以你必须考虑其它的应用程序可能滥用他们。一些须要考虑的事情是:

      1. 意图命名空间是全局。确保意图动作名称和其它的字符串写入一个你自己的命名空间中,否则你可能会无意中与其它应用程序发生冲突。
      2. 你使用registerReceiver(BroadcastReceiver,
        IntentFilter)
        。不论什么应用程序能够发送广播接收器,注冊。

        你能够控制谁能够发送广播。它通过权限描写叙述例如以下。

      3. 当你公布一个接收器在你的应用程序清单并为其指定的intent过滤器,不论什么其它的应用程序能够发送广播,它无论你指定的过滤器。

        要防止其它人发送给它,使它无法使用android:exported="false".

      4. 当你使用sendBroadcast(Intent) 或相关的方法,通常不论什么其它应用程序能够接收这些广播节目。

        你能够通过广播接收权限控制谁能够接收。

        另外,通过ICE_CREAM_SANDWICH,,你也能够用Intent.setPackage限定广播在一个应用中存在

    2. 使用 LocalBroadcastManager时这些问题不存在。由于它从来没有意图去运行当前进程外。
    3. 訪问权限能够通过发送者或接收者广播一个运行。
    4. 强制许可发送时,你提供非空的权限 sendBroadcast(Intent, String) 或者sendOrderedBroadcast(Intent,
      String, BroadcastReceiver, android.os.Handler, int, String, Bundle)
      。仅仅有那些被授予此权限接收器(通过请求与 <uses-permission> 标签在AndroidManifest.xml)将可以接收广播。

    5. 强制接收时,注冊广播时候你提供非空权限——要么当调用registerReceiver(BroadcastReceiver,
      IntentFilter, String, android.os.Handler)
       或者在你的AndroidManifest.xml静态 <receiver> 标签。

      仅仅有那些已被授予该权限的广播(通过在AndroidManifest.xml的 <uses-permission>标签。

      )将可以发送一个意图接收器。

    6. Security and Permissions 文档了解一般的权限和安全性。

  2. 接收生命周期
    1. 一个BroadcastReceiver对象仅仅有唯一有效的调用 onReceive(Context,
      Intent)
      。你从这个函数返回的代码,系统考虑该对象完毕还是失效。

    2. onReceive(Context,
      Intent)
      运行这具有重要的影响:不论什么须要异步操作是不可用的,由于你将须要从函数返回来处理异步操作,但在这一点上BroadcastReceiver不在活跃。异步操作完毕之前这种系统是免费的删除过程。
    3. 特别是,你可能不会显示一个对话框或绑定到一个服务于一个BroadcastReceiver。对于前者,你反而应该用NotificationManager API。对于后者,你能够使用Context.startService()将命令发送到服务。
  3. 过程生命周期
    1. 眼下正在运行中的boiadcastReceiver这一个过程。(也就是说,眼下在onReceive(Context,
      Intent)
       方法执行)被觉得是一个前景的过程,将保持执行的系统除了极端的内存压力的情况下。
    2. 一旦你返回onreceive()。BroadcastReceiver不再活跃,和其宿主进程仅仅为执行在它的不论什么其它应用程序组件一样重要。这是特别重要的,由于假设仅仅是举办过程中(的应用程序,用户没有或不近期互动的一个常见的情况),然后在从onreceive()系统还将考虑其过程是空的,积极地杀死它使资源可用于其它更重要的过程。

    3. 这意味着更长的执行操作,你会常常在一个BroadcastReceiver把含有进程的积极为您的整个操作时间的同一时候使用一个服务。

嵌套类

状态的结果正在等待一个广播接收器

BroadcastReceiver类中方法

BroadcastReceiver类的更多相关文章

  1. 【java回调】java两个类之间的回调函数传递

    背景交代:熟悉用js开发的cordovaAPP:对java一窍不通的我,老师让做一个监测用户拍照事件的功能,无奈没有找到现成的库,无奈自己动手开发java插件~~0基础java GreenHand,祝 ...

  2. BroadcastReceiver注册、使用及其权限

    首先声明一个类,此类继承自BroadcastReceiver类,处理Android当中发出的广播事件: public class SMSReceiver extends BroadcastReceiv ...

  3. Android四大组件之—— BroadcastReceiver的使用

    BroadcastReceiver又名广播接收者.既然它用于接收广播,那一定就有人负责发送. Android系统中的广播: 在现实生活中,我们都知道广播是什么,用来做什么.例如公园里的广播,主要通知游 ...

  4. Android的BroadcastReceiver 广播 短信拦截

    如何去理解BroadcastReceiver(广播)?其实可以这样想,首先我们要有一个发送广播的"媒体",在这个例子中,我们暂且用activity组件作为这个媒体,当然以后会用到s ...

  5. [置顶] Android四大组件之BroadcastReceiver

    Android四大组件之BroadcastReceiver Broadcast Receiver 广播接收器,是一种负责接收广播消息并对消息做出响应的组件,和Service一样并不提供与用户交互的UI ...

  6. Android应用开发学习笔记之BroadcastReceiver

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz 一.BroadcastReceiver机制概述 Broadcast Receiver是Android的一种“广播发布 ...

  7. 用BroadcastReceiver监听手机网络状态变化

    android--解决方案--用BroadcastReceiver监听手机网络状态变化 标签: android网络状态监听方案 2015-01-20 15:23 1294人阅读 评论(3) 收藏 举报 ...

  8. BroadcastReceiver学习

    一.使用系统广播.以监听电话状态为例 1.写一个类继承自BroadcastReceiver类 package com.diysoul.android.blacklist.receivers; impo ...

  9. Android BroadcastReceiver使用

    1. 介绍 BroadcastReceiver用于接收广播事件(Intent), 是Android四大组件之一 2. 使用 2.1  实现广播接收类 实现一个广播收类继承BroadcastReceiv ...

随机推荐

  1. BZOJ 4756 线段树合并(线段树)

    思路: 1.最裸的线段树合并 2. 我们可以观察到子树求一个东西 那我们直接DFS序好了 入队的时候统计一下有多少比他大的 出的时候统计一下 减一下 搞定~ 线段树合并代码: //By SiriusR ...

  2. LyX初步

    最近写毕业论文少量入手了LyX. 这个工具是两三年前在CTeX群里听说的.当时感觉太高大上,连Linux下用LaTeX都还没搞定,于是没想这个. 但是最近用了LaTeX模板感觉太麻烦,于是试着装了一下 ...

  3. angular4搭建博客(一)

    本文长期更新,未经运行,严禁转载. 博客(制作中) http://101.200.58.228/ Github https://github.com/Teloi/TEIndex 框架选择 Angula ...

  4. Java单例模式 多种实现方式

    一:通过静态私有成员实现单例模式 (1):私有化构造函数 (2):new静态实例属性对象,加锁. 单例类: package SinglePag; /* * 构造函数私有化,结合锁+静态的概念 实现单例 ...

  5. hdu3572Task Schedule 最大流,判断满流 优化的SAP算法

    PS:多校联赛的题目质量还是挺高的.建图不会啊,看了题解才会的. 参考博客:http://blog.csdn.net/luyuncheng/article/details/7944417 看了上面博客 ...

  6. TD中INPUT的宽度设置

    最近在用C#做Web程序时,碰到一个问题: 将TextBox的asp控件放在Table中的TD里面时,不设置宽度,自动会将TD撑的很大. 查看运行后页面的源代码发现,其实TextBox控件最终在客户端 ...

  7. 基于物品的协同过滤ItemCF的mapreduce实现

    文章的UML图比较好看..... 原文链接:www.cnblogs.com/anny-1980/articles/3519555.html 基于物品的协同过滤ItemCF 数据集字段: 1.  Use ...

  8. 脚本编写 nginx 启动

    #!bin/bash#功能:本脚本编写完成后,放置在/etc/init.d/目录下,就可以被 Linux 系统自动识别到该脚本.#如果本脚本命名为/etc/init.d/nginx,则 service ...

  9. Spring cloud公共模块

    1.0公共的模块是公共的工具包以及实体等 2.添加架包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xs ...

  10. 团体程序设计天梯赛-练习集-L1-027. 出租

    L1-027. 出租 下面是新浪微博上曾经很火的一张图: 一时间网上一片求救声,急问这个怎么破.其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,i ...