安卓Activity执行finish后onNewIntent也执行了

测试反应投屏时下一集可能播放不成功。

首先看一下日志:

onCompletion

onCast

handlerMessage: 2

finish: PlayerActivity@abc7fdc

onPause: PlayerActivity@abc7fdc

onNewIntent: PlayerActivity@abc7fdc

onResume: PlayerActivity@abc7fdc

onPause: PlayerActivity@abc7fdc

onResume: HomeActivity@71ec50a

onstop: PlayerActivity@abc7fdc

onDestroy:PlayerActivity@abc7fdc

看到日志时很迷惑,为什么 finish 了,安卓还会执行onNewIntent,不应该是新建一个 activity 吗?

先来看一下场景描述:

视频播完后会发送一个 finish 信息,如果 3s 内没有下一个视频进来就会执行 finish,有视频进来就会在 onNewIntent 中 remove 掉这条信息。

经过实验和详细分析后,终于找到了问题原因:

首先因为视频播放结束发了一条finish消息,finish消息没有执行时突然来了下一集的消息,这时候执行startActivty会插入一条onNewIntent消息。结果,这时候finish因为时间到了,该执行了。然后 finish 执行完后,onNewIntent 也该执行了。执行完后因为 finish 的原因, onDestroy也执行了。结果就是下一集没播完就退出来了。

解决办法:在startActivity前remove掉finish消息,比onNewIntent 的时间节点还要提前。

参考

面试必备:Android(9.0)Activity启动流程(一) : https://juejin.cn/post/6844903959581163528

面试必备:Android(9.0)Activity启动流程(二) : https://juejin.cn/post/6844903959589552142

android - onNewIntent called after finish() executed - Stack Overflow

相关推荐
zopple8 小时前
Laravel9.X重磅升级:十大核心特性解析
android
私人珍藏库9 小时前
【windows】跨平台 Android 刷机Root工具箱
android·windows·工具·刷机·软件·多功能
summerkissyou198711 小时前
Android-MediaSession-播放流程和例子
android·mediasession
私人珍藏库12 小时前
[Android] 蓝叠模拟器工具箱v1.1
android·智能手机·app·工具·软件·多功能
云霄IT13 小时前
安卓开发之java转dex再转smali
android·java·python
XiaoLeisj14 小时前
Android 短视频项目实战:从用户中心页与沉浸式登录,到验证码鉴权、用户信息持久化和 EventBus 登录态同步
android·webview·eventbus·countdowntimer·token 加密·键值对存储 sp·封装toast/加载 ui
JJay.15 小时前
Android BLE 扫描连接与收发消息实战
android
fly spider16 小时前
MySQL索引篇
android·数据库·mysql
xinhuanjieyi16 小时前
php setplayersjson实现类型转换和文件锁定机制应对高并发
android·开发语言·php
533_17 小时前
[vxe-table] 表头:点击出现输入框
android·java·javascript