Kotlin协程Flow流buffer缓冲批量任务或数据,条件筛选任务或数据

Kotlin协程Flow流buffer缓冲批量任务或数据,条件筛选任务或数据

Kotlin 复制代码
import kotlinx.coroutines.channels.BufferOverflow
import kotlinx.coroutines.flow.asFlow
import kotlinx.coroutines.flow.buffer
import kotlinx.coroutines.flow.onEach
import kotlinx.coroutines.flow.onStart
import kotlinx.coroutines.runBlocking

fun main() {
    runBlocking {
        var eachFlag = true
        var collectFlag = true

        (0..50)
            .chunked(5) //切块,分区
            .asFlow()
            .onStart { println("onStart") }
            .onEach { itList ->
                //假设这里是生产者,密集生产数据或任务

                collectFlag = true

                if (eachFlag) {
                    println("--------------------")
                    eachFlag = false
                }

                print("onEach [ ")
                itList.forEach { itData ->
                    print("$itData ")
                }
                print("]")

                println()
            }
            .buffer(capacity = 3, onBufferOverflow = BufferOverflow.SUSPEND)
            .collect { itList ->
                //假设这里是消费者,这里的消费者以一定的耗时完成任务或消费数据

                eachFlag = true

                if (collectFlag) {
                    println("↓")
                    collectFlag = false
                }

                print("collect [ ")
                itList.forEach { itData ->
                    print("$itData ")
                }
                print("]")

                val sortedList = itList.sortedBy { it }
                print(" 最大值=${sortedList.lastOrNull()} 最小值=${sortedList.firstOrNull()}")

                println()
            }
    }
}

输出:

onStart


onEach [ 0 1 2 3 4 ]

onEach [ 5 6 7 8 9 ]

onEach [ 10 11 12 13 14 ]

onEach [ 15 16 17 18 19 ]

onEach [ 20 21 22 23 24 ]

collect [ 0 1 2 3 4 ] 最大值=4 最小值=0

collect [ 5 6 7 8 9 ] 最大值=9 最小值=5

collect [ 10 11 12 13 14 ] 最大值=14 最小值=10

collect [ 15 16 17 18 19 ] 最大值=19 最小值=15

collect [ 20 21 22 23 24 ] 最大值=24 最小值=20


onEach [ 25 26 27 28 29 ]

onEach [ 30 31 32 33 34 ]

onEach [ 35 36 37 38 39 ]

onEach [ 40 41 42 43 44 ]

onEach [ 45 46 47 48 49 ]

collect [ 25 26 27 28 29 ] 最大值=29 最小值=25

collect [ 30 31 32 33 34 ] 最大值=34 最小值=30

collect [ 35 36 37 38 39 ] 最大值=39 最小值=35

collect [ 40 41 42 43 44 ] 最大值=44 最小值=40

collect [ 45 46 47 48 49 ] 最大值=49 最小值=45


onEach [ 50 ]

collect [ 50 ] 最大值=50 最小值=50

相关:

https://blog.csdn.net/zhangphil/article/details/132527122

https://blog.csdn.net/zhangphil/article/details/139237348

相关推荐
Kiri霧3 小时前
Kotlin递归
android·开发语言·kotlin
普通网友3 小时前
Android开发:使用Kotlin+协程+自定义注解+Retrofit的网络框架
android·kotlin·retrofit
常利兵3 小时前
Kotlin抽象类与接口:相爱相杀的编程“CP”
android·开发语言·kotlin
Arkerman_Liwei3 小时前
Android 新开发模式深度实践:Kotlin + 协程 + Flow+MVVM
android·开发语言·kotlin
蹦哒3 小时前
Kotlin DSL 风格编程详解
android·开发语言·kotlin
JJay.15 小时前
Kotlin 高阶函数学习指南
android·开发语言·kotlin
android_cai_niao15 小时前
kotlin中的when
kotlin·when
渔舟小调15 小时前
后端框架选型:为什么选Kotlin + Spring Boot
kotlin·idea
jinanwuhuaguo15 小时前
截止到4月8日,OpenClaw 2026年4月更新深度解读剖析:从“能力回归”到“信任内建”的范式跃迁
android·开发语言·人工智能·深度学习·kotlin
JJay.16 小时前
Android Kotlin 协程使用指南
android·开发语言·kotlin