只是一个简单的问题。我们在这里有一些误解。等待Task.WhenAll vs ..select(async .. =>等待)
我们:
var tasks = files.Select(async fileName => await IngestFileAsync(container, fileName));
var results = await Task.WhenAll(tasks);
我说的第一行还行并发的,但我的同事的同事说,否则。此外,他说第二个await
没有意义,因为所有 行动已经执行。
是这个代码,然后是相同的:
var tasks = files.Select(fileName => IngestFileAsync(container, fileName));
var results = await Task.WhenAll(tasks);
为:
var tasks = files.Select(async fileName => await IngestFileAsync(container, fileName));
var results = Task.WhenAll(tasks);
可能有人照这一些额外的光?
欢呼声。
新增: oke,所以它会同时运行。
然而,有人可以添加一些额外的信息不同的是,这些代码段之间是什么: https://dotnetfiddle.net/lzv2B7 https://dotnetfiddle.net/dMusus
(通知行16,async
和await
)。那两个有什么区别? 我会想到的是,与异步和等待它会直接启动,如果没有,那当谈到Await Task.WhenAll(tasks);
添加clearity它会开始 - 这是我的代码 - :
private async Task<Result> IngestFilesAsync(ICloudBlobContainer container, IEnumerable<string> files)
{
_logger.LogDebug("Start IngestFilesAsync");
var tasks = files.Select(fileName => IngestFileAsync(container, fileName));
var results = await Task.WhenAll(tasks);
_logger.LogDebug("All tasks completed");
if (results.Any(t => t.IsFailure))
{
return Result.Fail(string.Join(",", results.Select(f => f.Error)));
}
return Result.Ok();
}
private async Task<Result> IngestFileAsync(ICloudBlobContainer container, string fileName)
{
_logger.LogDebug("Start IngestFileAsync");
var blob = container.GetBlockBlobReference(fileName);
_logger.LogDebug("Blob retrieved");
if (await blob.ExistsAsync())
{
using (var memoryStream = new MemoryStream())
{
_logger.LogDebug("Start download to stream");
await blob.DownloadToStreamAsync(memoryStream);
_logger.LogDebug("To mem downloaded");
_logger.LogDebug("Start ftp-upload");
return await _targetFTP.UploadAsync(memoryStream, fileName);
}
}
_logger.LogWarning("Blob does not exists");
return Result.Fail($"Blob '{fileName}' does not exist");
}
其中_targetFTP.UploadAsync(memoryStream, fileName);
又是一项任务等等。
只需重写这两种情况下为'foreach'环路(而不是'Select') - 你得到答案马上 – Fabio
这很容易测试:让你的异步函数'Task.Delay'并测量需要多长时间。 – hvd
@fidor在我的日志中,我看到了彼此之后的重复行,这表明它们是并发执行的。现在我正在打字,可能会有来自这里的细线。 –