gpt4 book ai didi

c# - 限制任务并行库中的线程数

转载 作者:太空狗 更新时间:2023-10-29 20:04:40 28 4
gpt4 key购买 nike

我有几百个文件需要上传到 Azure Blob 存储。
我想使用并行任务库。
但是,不是运行所有 100 个线程以在文件列表的 foreach 中上传,我如何限制它可以使用的最大线程数并并行完成作业。还是它会自动平衡事物?

最佳答案

你根本不应该为此使用线程。为此有一个基于 Task 的 API,它自然是异步的:CloudBlockBlob.UploadFromFileAsync .将其与 async/awaitSemaphoreSlim 一起使用以限制并行上传的数量。

示例(未经测试):

const MAX_PARALLEL_UPLOADS = 5;

async Task UploadFiles()
{
var files = new List<string>();
// ... add files to the list

// init the blob block and
// upload files asynchronously
using (var blobBlock = new CloudBlockBlob(url, credentials))
using (var semaphore = new SemaphoreSlim(MAX_PARALLEL_UPLOADS))
{
var tasks = files.Select(async(filename) =>
{
await semaphore.WaitAsync();
try
{
await blobBlock.UploadFromFileAsync(filename, FileMode.Create);
}
finally
{
semaphore.Release();
}
}).ToArray();

await Task.WhenAll(tasks);
}
}

关于c# - 限制任务并行库中的线程数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23105748/

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