我们有以下代码(在本网站上找到此代码的想法),它将为方法“Do_SomeWork()”生成新线程。这使我们可以异步多次运行该方法。
代码是:
var numThreads = 20;
var toProcess = numThreads;
var resetEvent = new ManualResetEvent(false);
for (var i = 0; i < numThreads; i++)
{
new Thread(delegate()
{
Do_SomeWork(Parameter1, Parameter2, Parameter3);
if (Interlocked.Decrement(ref toProcess) == 0) resetEvent.Set();
}).Start();
}
resetEvent.WaitOne();
但是我们想要使用ThreadPool而不是创建我们自己的新线程,这可能对性能有害。问题是我们如何修改上面的代码以使用ThreadPool,记住方法“Do_SomeWork”采用多个参数并且还有一个返回类型(即方法不是空的)。
此外,这是C#2.0。
答案 0 :(得分:8)
几乎相同的方式,但使用传递给ThreadPool.QueueUserWorkItem的WaitCallback:
var numThreads = 20;
var toProcess = numThreads;
var resetEvent = new ManualResetEvent(false);
for (var i = 0; i < numThreads; i++)
{
ThreadPool.QueueUserWorkItem (
new WaitCallback(delegate(object state) {
Do_SomeWork(Parameter1, Parameter2, Parameter3);
if (Interlocked.Decrement(ref toProcess) == 0) resetEvent.Set();
}), null);
}
resetEvent.WaitOne();
答案 1 :(得分:0)
使用C#2.0,您可以调用
ThreadPool.QueueUserWorkItem(callback, new object[] { parm1, parm2, etc });
然后在回调中将对象[]转换回正确的参数和类型。关于返回类型,如果使用ThreadPool我不认为你将能够获得返回值,则回调必须具有
的签名
void Callback (object parm)