如果ThreadPool已满,则如何使Action.BeginInvoke生成非线程池线程

时间:2009-02-23 23:07:37

标签: c# multithreading .net-3.5 asynchronous

在.net 3.5

当ThreadPool没有可用线程时尝试ThreadPool.QueueUserWorkItem(a=> {Work()});导致BeginInvoke锁定。

void Work()
{
   Action executor = () = { DoSomething(); };
   IAsyncResult result = executor.BeginInvoke(null, null);

   using (WaitHandle hWait = result.AsyncWaitHandle)
   {
      if (hWait.WaitOne(timeoutMilliseconds))
      {
        executor.EndInvoke(result);
      }
      else
      {  throw new ImDyingException(); }
   }
}

如何让BeginInvoke使用非池化线程?

1 个答案:

答案 0 :(得分:5)

你做不到。听起来你大大超过了游泳池。也许考虑一个受限制的队列/自定义线程池(即同步的生产者/消费者队列)?

(不要增加池大小;这几乎总是采取错误的方法)