gpt4 book ai didi

android - 限制可以在范围内运行的最大协程数

转载 作者:行者123 更新时间:2023-12-04 23:16:11 25 4
gpt4 key购买 nike

我正在将我们当前的应用程序从 Java 转换为 Kotlin,我遇到了这个问题。

用于使用线程从服务器传输数据的 java 实现。

它将创建大约 100 个不同的线程来请求数据,但据我所见,一次运行的线程不超过 4 个,其他线程将等待线程完成后再开始。

在将它翻译成 Kotlin 时,我使用了 Coroutines

这会产生一个问题,因为服务器显然无法处理实际发送的 100 个请求。

所有协程都在同一个范围内启动,所以它是这样的:

//this is a custom scope that launches on Dispatchers.IO + a job that I can use to cancel everything
transferScope.launch {
//loadData is a suspending function that returns true/false
val futures = mDownloadJobs.map{ async { it.loadData() } }
val responses = futures.awaitAll()
//check that everything in responses is true etc....
}

有没有办法让特定的 transferScope 一次只允许最多 5 个协程,然后当一个完成时让另一个运行? (我不在乎顺序)

如果不能通过范围完成,有没有不同的方法可以实现?

最佳答案

要求每个协程获取 Kotlin Semaphore 在提出请求之前从总共 5 个许可中获得许可。

像这样的东西:

    import kotlinx.coroutines.sync.Semaphore

val requestSemaphore = Semaphore(5)

val futures = mDownloadJobs.map {
async {
// Will limit number of concurrent requests to 5
requestSemaphore.withPermit {
it.loadData()
}
}
}

val responses = futures.awaitAll()

关于android - 限制可以在范围内运行的最大协程数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58428584/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com