安卓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 原生定位(替代高德 / 百度等三方定位)<终极版本>
android
2501_916008892 小时前
iOS 抓包工具有哪些?全面盘点主流工具与功能对比分析
android·ios·小程序·https·uni-app·iphone·webview
2501_915921432 小时前
iOS混淆工具实战 视频流媒体类 App 的版权与播放安全保护
android·ios·小程序·https·uni-app·iphone·webview
CYRUS_STUDIO3 小时前
LLVM 全面解析:NDK 为什么离不开它?如何亲手编译调试 clang
android·编译器·llvm
CYRUS_STUDIO3 小时前
静态分析神器 + 动态调试利器:IDA Pro × Frida 混合调试实战
android·逆向
g_i_a_o_giao6 小时前
Android8 binder源码学习分析笔记(一)
android·java·笔记·学习·binder·安卓源码分析
翻滚丷大头鱼6 小时前
android 四大组件—BroadcastReceiver
android
人生游戏牛马NPC1号6 小时前
学习 Android (二十) 学习 OpenCV (五)
android·opencv·学习
2501_916008896 小时前
uni-app iOS 日志与崩溃分析全流程 多工具协作的实战指南
android·ios·小程序·https·uni-app·iphone·webview
文 丰6 小时前
【AndroidStudio】官网下载免安装版,AndroidStudio压缩版的配置和使用
android