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 怎么看?

相关推荐
奔跑中的蜗牛6666 小时前
直播APP架构升级和性能优化:WebView 容器化
android
学习编程之路6 小时前
仓颉多态性应用深度解析
android·多态·仓颉
俩个逗号。。6 小时前
ViewPager+Fragment 切换主题崩溃
android·android studio·android jetpack
IT乐手6 小时前
Okhttp 定制打印请求日志
android
来之梦6 小时前
Android红包雨动画效果实现 - 可自定义的扩散范围动画组件
android
杨筱毅6 小时前
【Android】【JNI多线程】JNI多线程安全、问题、性能常见卡点
android·jni
散人10246 小时前
Android Service 的一个细节
android·service
安卓蓝牙Vincent7 小时前
《Android BLE ScanSettings 完全解析:从参数到实战》
android
江上清风山间明月7 小时前
LOCAL_STATIC_ANDROID_LIBRARIES的作用
android·静态库·static_android