gpt4 book ai didi

c# - 快速高效地下载多个文件(异步)

转载 作者:太空狗 更新时间:2023-10-30 00:19:12 24 4
gpt4 key购买 nike

我有很多文件需要下载。所以我尝试使用如下所示的新异步功能的强大功能。

var streamTasks = urls.Select(async url => (await WebRequest.CreateHttp(url).GetResponseAsync()).GetResponseStream()).ToList();

var streams = await Task.WhenAll(streamTasks);
foreach (var stream in streams)
{
using (var fileStream = new FileStream("blabla", FileMode.Create))
{
await stream.CopyToAsync(fileStream);
}
}

我担心这段代码会导致大量内存使用,因为如果有 1000 个包含 2MB 文件的文件,那么这段代码会将 1000*2MB 流加载到内存中?

我可能遗漏了什么或者我完全正确。如果我没有错过任何东西,那么最好等待每个请求并使用流是最好的方法?

最佳答案

这两种选择都可能有问题。一次只下载一个文件不会扩展并且需要时间,而一次下载所有文件可能会造成过多的负载(另外,无需等待所有文件下载完毕再进行处理)。

我更喜欢始终使用可配置的大小来限制此类操作。一个简单的方法是使用 AsyncLock (利用 SemaphoreSlim )。更稳健的方法是使用 TPL DataflowMaxDegreeOfParallelism .

var block = new ActionBlock<string>(url =>
{
var stream = (await WebRequest.CreateHttp(url).GetResponseAsync()).GetResponseStream();
using (var fileStream = new FileStream("blabla", FileMode.Create))
{
await stream.CopyToAsync(fileStream);
}
},
new ExecutionDataflowBlockOptions { MaxDegreeOfParallelism = 100 });

关于c# - 快速高效地下载多个文件(异步),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23891726/

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