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

相关推荐
雨白5 小时前
Jetpack系列(二):Lifecycle与LiveData结合,打造响应式UI
android·android jetpack
kk爱闹6 小时前
【挑战14天学完python和pytorch】- day01
android·pytorch·python
每次的天空8 小时前
Android-自定义View的实战学习总结
android·学习·kotlin·音视频
恋猫de小郭9 小时前
Flutter Widget Preview 功能已合并到 master,提前在体验毛坯的预览支持
android·flutter·ios
断剑重铸之日10 小时前
Android自定义相机开发(类似OCR扫描相机)
android
随心最为安10 小时前
Android Library Maven 发布完整流程指南
android
岁月玲珑10 小时前
【使用Android Studio调试手机app时候手机老掉线问题】
android·ide·android studio
还鮟14 小时前
CTF Web的数组巧用
android
小蜜蜂嗡嗡15 小时前
Android Studio flutter项目运行、打包时间太长
android·flutter·android studio
aqi0015 小时前
FFmpeg开发笔记(七十一)使用国产的QPlayer2实现双播放器观看视频
android·ffmpeg·音视频·流媒体