List<Task> 不总是并行运行有什么原因吗?

当我需要一些并行处理时,我通常会这样做:


static void Main(string[] args)

{

    var tasks = new List<Task>();

    var toProcess = new List<string>{"dog", "cat", "whale", "etc"};

    toProcess.ForEach(s => tasks.Add(CanRunAsync(s)));

    Task.WaitAll(tasks.ToArray());

}


private static async Task CanRunAsync(string item)

{

    // simulate some work

    await Task.Delay(10000);

}

我遇到过这样的情况,它没有并行处理项目,不得不使用Task.Run它来强制它在不同的线程上运行。


我错过了什么?


回首忆惘然
浏览 221回答 1
1回答

慕的地8271018

Task意思是“需要做的事情,可能已经完成,可能正在并行线程上执行,或者可能取决于进程外数据(套接字等),或者可能只是......连接到交换机某处说“完成”” - 它与线程几乎没有关系,除了:如果你安排一个延续(又名await),那么不知何故需要回到一个线程来触发,但这是如何发生的以及那是什么手段取决于创建的任何代码并拥有该任务。注意:并行性可以表示为多个任务(如果您愿意的话),但多个任务并不意味着并行性。在您的情况下:这完全取决于做什么CanRun或是什么-我们不知道。它也应该被称为CanRunAsync.
打开App,查看更多内容
随时随地看视频慕课网APP