为什么不能直接在BroadCastReceiver中开一个线程执行耗时任务

BroadCastReceiver的生命周期非常简短:接收到广播→onReceive()→结束;

所以在onReceive方法中,不要执行耗时的任务,如果该方法执行时间超过10秒,Android就会认为该程序无响应,并弹出ANR的对话框。如果必须执行耗时任务可以考虑,在onReceive中开启服务来执行,但不要使用线程,因为BroadCastReceiver的生命周期很短,可能出现子线程还没有结束,BroadCastReceiver就已经退出了。

如果当BroadCastReceiver所在的进程结束,虽然该进程中可能有用户启动的新线程,但是由于该进程内没有活动的组件,系统会在内存紧张的时候,优先结束掉该进程,这就会导致BroadCastReceiver启动的子线程不能执行完。

转载地址

在 Service 类下,可以创建一个 BroadcastReceiver 类来处理开始和暂停音乐播放的按钮点击事件。可以按照以下步骤实现: 1. 在 Service 类中创建一个内部类 BroadcastReceiver,继承自 BroadcastReceiver 类,并实现 onReceive() 方法。 2. 在 onReceive() 方法中,处理开始和暂停按钮的点击事件。可以通过判断当前音乐播放状态,执行相应的操作。 3. 在 Service 类中创建一个 MediaPlayer 对象,在 onReceive() 方法中控制音乐播放状态。 4. 在 Activity 中,注册 BroadcastReceiver,并发送相应的 Intent。 以下是示例代码: ```kotlin class MusicService : Service() { inner class MusicReceiver : BroadcastReceiver() { override fun onReceive(context: Context?, intent: Intent?) { if (intent?.action == "ACTION_PLAY_PAUSE") { if (mediaPlayer.isPlaying) { mediaPlayer.pause() } else { mediaPlayer.start() } } } } private lateinit var mediaPlayer: MediaPlayer private lateinit var musicReceiver: MusicReceiver override fun onCreate() { super.onCreate() mediaPlayer = MediaPlayer.create(this, R.raw.music) musicReceiver = MusicReceiver() val intentFilter = IntentFilter("ACTION_PLAY_PAUSE") registerReceiver(musicReceiver, intentFilter) } override fun onDestroy() { super.onDestroy() unregisterReceiver(musicReceiver) mediaPlayer.release() } override fun onBind(intent: Intent): IBinder? { return null } } ``` 在 Activity 中发送 Intent: ```kotlin val intent = Intent("ACTION_PLAY_PAUSE") sendBroadcast(intent) ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值