LiveData 里面 Transformations 的 map 以及 switchMap

本文详细介绍了 Android LiveData 的 Transformations 中的 map 和 switchMap 的工作原理和区别。通过代码示例展示了如何使用它们,并解释了为何在特定场景下选择 switchMap 而不是 map,主要关注它们在数据流更新和响应中的行为差异。
摘要由CSDN通过智能技术生成

假设在一个实现了 viewmodel 的类里面有如下代码:

private val queryLiveData = MutableLiveData<String>()    
    private val repoResult: LiveData<RepoSearchResult> = Transformations.map(queryLiveData) {
        repository.search(it)
    }

    val repos: LiveData<List<Repo>> = Transformations.switchMap(repoResult) {
        it.data
    }

    fun searchRepo(queryString: String) {
        queryLiveData.postValue(queryString)
    }

如上代码演示了 Transformations map 的应用。如果调用 searchRepo 方法,queryLiveData 会给订阅了它的 observer 发送通知,可是这里的代码并没有显示的 observer 订阅,当然这个操作还是存在的,只是 map 函数帮我们操作了。如上调用的 map 函数我们传入了 queryLiveData 这个 LiveData 以及一个 Function 代码 块,只不过是上面的 map 函数使用了 lambda 的简写,将代码块卸载了括号外面。看下 map 代码的实现:

@MainThread
@NonNull
public static <X, Y> LiveData<Y> map(
            @NonNull LiveData<X> source,
            @NonNull final Function<X, Y> mapFunction) {
        final MediatorLiveData<Y> result = new MediatorLiveData<>();
        result.addSource(source, new Observer<X>() {
            @Override
            public void onChanged(@Nullable X x) {
                result.setValue(map
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值