人人人人人人人人人人人人

c# Task waitAll,WhenAll, ContinueWith

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);

             });
        }

  

 

posted @ 2019-07-17 16:41  wgscd  阅读(7218)  评论(2编辑  收藏  举报