安卓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

相关推荐
李堇2 小时前
android滚动列表VerticalRollingTextView
android·java
lxysbly4 小时前
n64模拟器安卓版带金手指2026
android
游戏开发爱好者86 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
王码码20357 小时前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
黑码哥7 小时前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder
亓才孓7 小时前
[JDBC]元数据
android
独行soc7 小时前
2026年渗透测试面试题总结-17(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
金融RPA机器人丨实在智能7 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿7 小时前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市
独行soc8 小时前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮