wait 阻塞的 when是异步的非阻塞的。
Task[] tlist = new Task[] { Task.Run(() => { Thread.Sleep(3000); }), Task.Factory.StartNew(() => { Thread.Sleep(90000); }) }; //Task.WaitAll(tlist); // MessageBox.Show("ok "); Task.WhenAny(tlist).ContinueWith((s)=>{ MessageBox.Show("ok"); return s; });
上面是例子WhenAny 是任何一个任务完成就会执行 MessageBox.Show("ok"); 测试上面的例子等待3秒回OK。
如果换成WhenAll那你会等待90秒才会看到 MessageBox.Show("ok"); ContinueWith 就是任务完成后执行的方法体,
就是个Task. Task.WaitAll(tlist);意思是一样但是,线程会阻塞。因为 Task.WaitAll 不是一个异步或Task类型,而是一个常规方法体。
有了.Netframwork4.5的Task感觉比以前多线程简化很多也方便很多。基本可以抛弃 new Thread... 和BackgroundWorker了。
.Netframwork4.5里的Task.Run等效于 Task.Factory.StartNew 。Task.Factory.StartNew 在4.0里就有。
也可以 Task.ContinueWith 来得到回调的效果(用来获取Task执行完成后的结果)
private void button1_Click(object sender, EventArgs e)
{
TestWait().ContinueWith((s) =>
{
Invoke((Action)delegate
{
Text = s.Result;
});
});
}
private Task<string> TestWait()
{
return Task.Run(() =>
{
Thread.Sleep(2238);//or Task.WaitAll(Task.Delay(1000));
return Task.FromResult("" + DateTime.Now.Ticks);
});
}