thread.sleep“打破”任务
-
26-10-2019 - |
题
所以我有以下代码
Action d = () =>
{
for (int i = 0; i <= 10; i++)
{
Thread.Sleep(50);
Console.WriteLine("Task: {0} log:{1}",Thread.CurrentThread.ManagedThreadId,i);
}
};
Task.Factory.StartNew(d);
但是,它没有输出任何东西。但是,如果我评论线程。根据价值,使用不同的睡眠值会给我带来的结果或多或少。
为什么这样会发生这种方式?
解决方案
我怀疑您的程序在任务有机会运行之前已退出。
默认情况下,任务在线程池线程上运行,即背景线程。这意味着您的程序不会等待他们在退出之前完成。
尝试在主线程中添加此内容:
var task = Task.Factory.StartNew( d );
task.Wait();
其他提示
您是否正在等待任务完成任何地方,或者您的程序在完成任务之前是否退出?
Task task = Task.Factory.StartNew(d);
task.Wait();
我刚刚运行您的代码,然后输出:
Task: 10 log:0
Task: 10 log:1
Task: 10 log:2
Task: 10 log:3
Task: 10 log:4
Task: 10 log:5
Task: 10 log:6
Task: 10 log:7
Task: 10 log:8
Task: 10 log:9
Task: 10 log:10
这是基于我运行的代码应用程序的控制台代码:
using System.Threading;
using System.Threading.Tasks;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
Action d = () =>
{
for (int i = 0; i <= 10; i++)
{
Thread.Sleep(50);
Console.WriteLine("Task: {0} log:{1}", Thread.CurrentThread.ManagedThreadId, i);
}
};
Task.Factory.StartNew(d);
Console.ReadLine();
}
}
}
不隶属于 StackOverflow