在.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使用非池化线程?
答案 0 :(得分:5)
你做不到。听起来你大大超过了游泳池。也许考虑一个受限制的队列/自定义线程池(即同步的生产者/消费者队列)?
(不要增加池大小;这几乎总是采取错误的方法)