.NET ValueTuple使用WhenAll获取多个任务结果

在.NET中,我们可以通过Task.WhenAll用来等待多个任务。任务完成之后,我们可以使用await等待他们来获取结果。

Task<int> task1 = Task.Run(() => 1);
Task<string> task2 = Task.Run(() => "hello");

await Task.WhenAll(task1, task2);
var task1Result = task1.Result; // or await task1
var task2Result = task2.Result; // or await task2

我们再来看一下如何用WhenAll方法来获取结果。

Task<int> task1 = Task.Run(() => 1);
Task<string> task2 = Task.Run(() => "hello");

var (task1Result, task2Result) = await Task.WhenAll(task1, task2);

当然我们可以编写一个带有任务结果的ValueTuple的自定义方法

public static class TaskEx
{
    public static async Task<(T0, T1)> WhenAll<T0, T1>(Task<T0> task0, Task<T1> task1)
    {
        await Task.WhenAll(task0, task1).ConfigureAwait(false);
        // It's ok to use task.Result here as the task is completed
        return (task0.Result, task1.Result);
    }

    public static async Task<(T0, T1, T2)> WhenAll<T0, T1, T2>(Task<T0> task0, Task<T1> task1, Task<T2> task2)
    {
        await Task.WhenAll(task0, task1, task2).ConfigureAwait(false);
        return (task0.Result, task1.Result, task2.Result);
    }

    public static async Task<(T0, T1, T2, T3)> WhenAll<T0, T1, T2, T3>(Task<T0> task0, Task<T1> task1, Task<T2> task2, Task<T3> task3)
    {
        await Task.WhenAll(task0, task1, task2, task3).ConfigureAwait(false);
        return (task0.Result, task1.Result, task2.Result, task3.Result);
    }

    public static async Task<(T0, T1, T2, T3, T4)> WhenAll<T0, T1, T2, T3, T4>(Task<T0> task0, Task<T1> task1, Task<T2> task2, Task<T3> task3, Task<T4> task4)
    {
        await Task.WhenAll(task0, task1, task2, task3, task4).ConfigureAwait(false);
        return (task0.Result, task1.Result, task2.Result, task3.Result, task4.Result);
    }

    public static async Task<(T0, T1, T2, T3, T4, T5)> WhenAll<T0, T1, T2, T3, T4, T5>(Task<T0> task0, Task<T1> task1, Task<T2> task2, Task<T3> task3, Task<T4> task4, Task<T5> task5)
    {
        await Task.WhenAll(task0, task1, task2, task3, task4, task5).ConfigureAwait(false);
        return (task0.Result, task1.Result, task2.Result, task3.Result, task4.Result, task5.Result);
    }

    public static async Task<(T0, T1, T2, T3, T4, T5, T6)> WhenAll<T0, T1, T2, T3, T4, T5, T6>(Task<T0> task0, Task<T1> task1, Task<T2> task2, Task<T3> task3, Task<T4> task4, Task<T5> task5, Task<T6> task6)
    {
        await Task.WhenAll(task0, task1, task2, task3, task4, task5, task6).ConfigureAwait(false);
        return (task0.Result, task1.Result, task2.Result, task3.Result, task4.Result, task5.Result, task6.Result);
    }
}

最后我们就可以通过下面代码片段去调用它了

Task<int> task1 = Task.Run(() => 1);
Task<string> task2 = Task.Run(() => "hello");
Task<string> task2 = Task.Run(() => 'fh');

var (t1Result, t2Result, t3Result) = await TaskEx.WhenAll(task1, task2, task3);

posted @   HueiFeng  阅读(677)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示