[英]C#/XAML HTTPclient/webrequest GET with await never ends
[英]C# Tasks in a loop never ends
考慮以下代碼:
for (int i = 0; i < 1000000; i++)
{
int i1 = i;
Task.Run(() => Console.WriteLine(i1));
}
在上面的代碼中運行時,我編寫了一個從0到1000000的循環,循環從未完成。 為什么這個循環永遠不會完成?
那是因為您從不等待任務完成。 我希望您在控制台應用程序中運行它。 控制台線程實際上將在循環完成之前退出,因為Task.Run
與控制台應用程序的線程異步運行任務。
您要么等待任務完成,要么
for (int i = 0; i < 1000000; i++)
{
int i1 = i;
Task.Run(() => Console.WriteLine(i1)).Wait();
}
或者您保持控制台窗口打開
static void Main(string[] args)
{
for (int i = 0; i < 1000000; i++)
{
int i1 = i;
Task.Run(() => Console.WriteLine(i1));
}
Console.ReadKey();
}
或者您通過將所有任務添加到列表中並使用Task.WaitAll
等待所有任務完成
var tasks = new List<Task>();
for (int i = 0; i < 1000000; i++)
{
int i1 = i;
tasks.Add(Task.Run(() => Console.WriteLine(i1)));
}
Task.WaitAll(tasks.ToArray());
Task
正在后台線程中運行。 當主線程停止時,所有任務都將終止。 如果在代碼后添加Task.WaitAll
,它將可以正常工作。
List<Task> tasks = new List<Task>();
for (int i = 0; i < 10000; i++)
{
int i1 = i;
tasks.Add(Task.Run(() => Console.WriteLine(i1)));
}
Task.WaitAll(tasks.ToArray());
以下內容在具有Mono的OS X上完美運行:
using System.Threading.Tasks;
using System;
public class Test
{
public static int Main(string[] args)
{
for (int i = 0; i < 1000000; i++)
{
int i1 = i;
Task.Run(() => Console.WriteLine(i1));
}
return 0;
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.