Kotlin Flow 转换以及上下游处理

本片文章主要介绍Flow上下游处理,上游一个Flow使用map,上游两个Flow使用zip,上游三个Flow及以上使用combine

1、下面代码展示了upStreamFlow作为上游,downStreamFlow作为下游,通过对upStreamFlow使用map操作符函数将upStreamFlow转换为新的Flow对象,每个元素都通过lambda表达式进行处理,并生成以"Number:"为开头的字符串。

Kotlin 复制代码
package com.cqz

import kotlinx.coroutines.flow.*

suspend fun main() {
    val upStreamFlow: Flow<Int> = flow {
        for (i in 1..5) {
            emit(i)
        }
    }
    val downStreamFlow: Flow<String> = upStreamFlow.map {
        "Number:$it"
    }
    upStreamFlow.collect {
        println("upStreamFlow:$it")
    }
    downStreamFlow.collect {
        println("downStreamFlow:$it")
    }

}

运行以上代码将会得到以下结果

Kotlin 复制代码
upStreamFlow:1
upStreamFlow:2
upStreamFlow:3
upStreamFlow:4
upStreamFlow:5
downStreamFlow:Number:1
downStreamFlow:Number:2
downStreamFlow:Number:3
downStreamFlow:Number:4
downStreamFlow:Number:5

2、上游两个Flow可以使用zip操作符函数将两个Flow合并为新的Flow对象。这个函数接受两个asdFlow作为参数,并通过lambda表达式将它们的元素进行组合。

Kotlin 复制代码
package com.cqz

import kotlinx.coroutines.flow.*

suspend fun main() {
    val upStreamFlow: Flow<Int> = flow {
        for (i in 1..5) {
            emit(i)
        }
    }
    
    val upStream2Flow: Flow<Int> = flow {
        for (i in 6..10) {
            emit(i)
        }
    }
    upStreamFlow.zip(upStream2Flow) { num1,num2->
        num1 + num2
    }.collect {
        println("zip:$it")
    }
   
}

运行以上代码将会得到以下结果

Kotlin 复制代码
zip:7
zip:9
zip:11
zip:13
zip:15

3、上游有三个Flow或以上的时候可以使用combine操作符函数,将三个Flow合并为一个Flow

Kotlin 复制代码
package com.cqz

import kotlinx.coroutines.flow.*

suspend fun main() {

    val flow1 = flowOf(1,2,3)
    val flow2 = flowOf(false,true,false)
    val flow3 = flowOf("A","B","C")
   val combinedFlow = combine(flow1,flow2,flow3) {i, b, s ->
       CombinedResult(i,b,s)
   }
   combinedFlow.collect {
       println("combinedFlow:$it")
   }
}
data class CombinedResult(val i: Int,val b: Boolean,val str: String)

运行以上代码将会得到以下结果

Kotlin 复制代码
combinedFlow:CombinedResult(i=1, b=false, str=A)
combinedFlow:CombinedResult(i=2, b=false, str=A)
combinedFlow:CombinedResult(i=2, b=true, str=A)
combinedFlow:CombinedResult(i=2, b=true, str=B)
combinedFlow:CombinedResult(i=3, b=true, str=B)
combinedFlow:CombinedResult(i=3, b=false, str=B)
combinedFlow:CombinedResult(i=3, b=false, str=C)
相关推荐
lee_curry7 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
QQ1__8115175157 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态7 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子7 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室7 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI7 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing7 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者7 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册7 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李7 小时前
2026 年 Web 前端开发的 8 个趋势!
前端