码迷,mamicode.com
首页 > 其他好文 > 详细

TPL异步并行编程之回调

时间:2016-06-22 15:50:26      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

Task是基于ThreadPool线程池基础上的高度异步多线程编程,如果有一天我希望一个需要长时间运行的Task,在被某些异常终止后还能回调一些代码就可以知道Task终止的原因了吧

是的,且看代码

public static Task AsyncRun(this ILoggerProvider logProvider, Action task, TaskCreationOptions taskOption, Action<Exception> exceptionHandler)
{
  return Task.Factory.StartNew(task, taskOption).ContinueWith(t =>
  {
    if (exceptionHandler != null)
      exceptionHandler(t.Exception);
    else
    {
      if (logProvider.Logger.IsErrorEnabled)
      {
        for (var i = 0; i < t.Exception.InnerExceptions.Count; i++)
        {
          logProvider.Logger.Error(t.Exception.InnerExceptions[i]);
        }
      }
    }
  }, TaskContinuationOptions.OnlyOnFaulted);
}

 

Task.Factory.StartNew(()=>{

  while(true){

    //一个持续工作的线程

  }

}).ContinueWith(t=>{

  //我是这个线程的尾巴,因为线程由于某些原因被终止后会调用我,在这里我可以处理异常,以及其他事情

  //比如异常

  var exception=t.Exception;//此时我可以向外界或者日志输出异常终止的原因了

})

 

同时你还可以通过TaskContinuationOptions设置线程什么情况下才回调代码

 

 

技术分享

所以Task这个东西的确很方便,且很高效,对于像服务器多线程编程而言是非常有用的,而不是传统的直接new一个线程,让线程一直保持运行,那么服务器的线程将会达到一个非常高的值,反而降低进程性能,因为线程也会有不少的资源开销,特别是对于io频繁的系统来说。

 

TPL异步并行编程之回调

标签:

原文地址:http://www.cnblogs.com/rjjs/p/5607156.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!