Activity Result API 的缺点

startActivityForResult 已经标为废弃了,今天整理代码时,考虑把它换成 Activity Result API。所以去了解了一下。

关于 Activity Result API,郭神这篇文章很好地介绍过了:Activity Result API详解,是时候放弃startActivityForResult了

新的 API 不再需要我们维护 request code 了,我觉得这是一个大的提升。

但这个新 API 要求必须在 STARTED 生命周期前注册,也就是只能声明为全局饿汉式初始化,或者在 onCreate 中初始化,否则就会遇到这个 crash:

vbnet 复制代码
java.lang.IllegalStateException: LifecycleOwner XXXActivity@85b22d0 is attempting to register while current state is RESUMED. LifecycleOwners must call register before they are STARTED.
    at androidx.activity.result.ActivityResultRegistry.register(ActivityResultRegistry.java:121)
    at androidx.activity.ComponentActivity.registerForActivityResult(ComponentActivity.java:885)
    at androidx.activity.ComponentActivity.registerForActivityResult(ComponentActivity.java:894)

但有时候页面上只有一个小的功能需要用到这个回调,大部分用户都不会用到这个功能。所以这里最适合的初始化应该是懒汉式。

也就是说,用 Result API 多初始化了一个全局变量,用以前的 startActivityForResult 就没有这个问题。

虽然 Activity Result API 的注册本身非常轻量,不会带来太多性能开销,但却增加了代码复杂度。因为以前我读代码时,读到这个小功能才会看到 startActivityForResult,可以很自然地了解到它的作用。现在 Result API 是全局声明的,我会认为它是一个全局需要的东西,但实际上并不是,容易造成困惑。我觉得这是 Result API 的一个缺点。

所以要不要换成这个新 API 呢,我目前的选择是不换,jym 怎么看?

相关推荐
石山岭14 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧16 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
Kapaseker21 小时前
Kotlin Toolchain 0.11 发布:主要是把 Amper 干没了
android·kotlin
三少爷的鞋1 天前
Android 现代架构不需要事件总线进阶篇
android
杉氧2 天前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏2 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧2 天前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄2 天前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭2 天前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景2 天前
Kotlin Flow操作符学习
android·kotlin