Android面试题之Broadcast Receiver篇

前言

秋招在即,计蒙准备在国庆假期结束前整理一套Android初级面试题籍,希望对大家有所帮助


提示:以下是本篇文章正文内容

Broadcast Receiver

1.如何注册 BroadcastReceiver

在清单文件中注册广播接收者称为静态注册,在代码中注册称为动态注册。
静态注册的广播接收者只要 app 在系统中运行则一直可以接收到广播消息,
动态注册的广播接收者当注册的 Activity 或者 Service 销毁了那么就接收不到广播了。

静态注册:在清单文件中进行如下配置

<receiver android:name=".BroadcastReceiver1" > 
     <intent-filter>
        <action android:name="android.intent.action.CALL" > </action>
      </intent-filter> 
</receiver>

动态注册:在代码中进行如下注册

receiver = new BroadcastReceiver(); 
IntentFilter intentFilter = new IntentFilter(); 
intentFilter.addAction(CALL_ACTION);
context.registerReceiver(receiver, intentFilter);

2.Android 引入广播机制的用意

  • a.从 MVC 的角度考虑(应用程序内) 其实回答这个问题的时候还可以这样问,android 为什么要有那 四大组件,现在的移动开发模型基本上也是照搬的 web 那一套 MVC 架构,只不过是改了点嫁妆而已。android的四大组件本质上就是为了实现移动或者说嵌入式设备上的 MVC 架构,它们之间有时候是一种相互依存的关系,有时候又是一种补充关系,引入广播机制可以方便几大组件的信息和数据交互。
  • b.程序间互通消息(例如在自己的应用程序内监听系统来电)
  • c.效率上(参考 UDP 的广播协议在局域网的方便性)
  • d.设计模式上(反转控制的一种应用,类似监听者模式)

3.两种注册各有什么优缺点

静态注册

  • 常驻,当应用程序关闭后如果有信息广播来,程序也会被系统调用,自己运行。
  • 无需担忧广播接收器是否被关闭,只要设备是开启状态,广播接收器就是打开着的。

动态注册

  • 不常驻,广播会跟随程序的生命周期。
  • 在 Android 的广播机制中,动态注册优先级高于静态注册优先级,因此在必要情况下,是需要动态注册广播接收者的。
  • 当用来注册的 Activity 关掉后,广播也就失效了。

4.广播的类型

  • 普通广播:开发者自定义 intent 广播。
  • 系统广播:系统内置广播,如开机、网络状态变化。
  • 有序广播:发送出去的广播被广播接收者按照先后顺序接收,先接收道广播接受者可对广播进行修改或者截断,使用
    sendOrderedBroadcast(intent)。
  • 粘性广播:由于在 Android5.0 & API 21 中已经失效,所以不建议使用,在这里也不作过多的总结。
  • App 应用内广播:App 应用内广播可理解为一种局部广播,广播的发送者和接收者都同属于一个 App,(将 exported 属性设置为false)

5.BrocastReceiver 里能否进行耗时操作

不能,当 onReceive()方法在 10 s 内没有执行完毕,Android 会认为该程序无响应,所以在BroadcastReceiver 里不能做一些比较耗时的操作,否侧会弹出 ANR 的对话框。


6.描述一下广播 BroadcastReceiver 的理解

BroadCastReceiver 是 Android 四大组件之一,主要用于接收系统或者 app 发送的广播事件。广播分两种:有序广播和无序广播。
内部通信实现机制:通过 Android 系统的 Binder 机制实现通信。

  • 无序广播:完全异步,逻辑上可以被任何广播接收者接收到。优点是效率较高。缺点是一个接收者不能将处理结果传递给下一个接收者,并无法终止广播intent 的传播。
  • 有序广播:按照被接收者的优先级顺序,在被接收者中依次传播。比如有三个广播接收者 A,B,C,优先级是 A > B > C。那这个消息先传给A,再传给 B,最后传给 C。每个接收者有权终止广播,比如 B 终止广播,C 就无法接收到。此外 A接收到广播后可以对结果对象进行操作,当广播传给 B 时, B 可以从结果对象中取得 A 存入的数据。

在通过 Context.sendOrderedBroadcast(intent, receiverPermission, resultReceiver, scheduler, initialCode, initialData, initialExtras)时我们可以指定 resultReceiver 广播接收者。
这个接收者我们可以认为是最终接收者,通常情况下如果比他优先级更高的接收者如果没有终止广播,那么他的 onReceive 会被执行两次,第一次是正常的按照优先级顺序执行,第二次是作为最终接收者接收。如果比他优先级高的接收者终止了广播,那么他依然能接收到广播。

在我们的项目中经常使用广播接收者接收系统通知,比如开机启动、sd 挂载、低电量、外播电话、锁屏等。

如果我们做的是播放器,那么监听到用户锁屏后我们应该将我们的播放之暂停等。


7.BrocastReceiver 的生命周期和注意事项

  • BroadCastReceiver 的生命周期很短暂,当接收到广播的时候创建,当onReceive()方法结束后销毁
  • 因为BroadCastReceiver的声明周期很短暂,所以不要在广播接收器中去创建子线程做耗时的操作,因为广播接受者被销毁后,这个子进程就会成为空进程,很容易被杀死
  • BroadCastReceiver是运行在主线程的,所以不能直接在BroadCastReceiver中去做耗时的操作,否则就会出现ANR异常

关于整理问题

当全部整理完毕后将整理成pdf格式,以方便阅读,文件获取如下图(10月8日后)


在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_42761395/article/details/108883248
今日推荐