What is the best way to launch 10 threads like in a for loop for a process intensive method. A code example would be very helpful.
for (int i = 0; i<=10; i++) //10 threads are intended.
{
LongRunningMethod();
}
-
Use Action as a delegate to create a new thread for each long running method call.
Action newThread = new Action(LongRunningMethod); // Call Async which is a new thread newThread.BeginInvoke(null, null);
Action with no template is only in .NET 3.5, for .NET 2.0 you have to declare a delegate
public delegate void NoParametersMethod(); NoParametersMethodnewThread = new NoParametersMethod(LongRunningMethod); // Call Async which is a new thread newThread.BeginInvoke(null, null);
KeeperOfTheSoul : Or use an existing one such as System.Threading.ThreadStartSTW : Delegate.BeginInvoke() utitizes the Remoting Messaging system and incurs a fair overhead, using ThreadPool.QueueUserWorkItem avoids this overhead -
ThreadPool.QueueUserWorkItem
Noam Gal : Just make sure you have enough MaxThreads in there (10, in this case), otherwise some of your threads will wait in the queue.Franci Penov : The thread pool is shared between your app and the CLR library. There are scenarios where using it might have negative effect on the app.Brian Rasmussen : We can't really tell what LongRunningMethod is doing, but given the name it is probably not optimal to use thread pool threads for this.Jonathan Shepherd : And you can even have more than 10 thread but only 10 will run at a time. -
Or if you don't want to use the thread pool, just create and start a new thread.
new Thread( delegate() { LongRunningMethod(); } ).Start();
P.K : just inquisitive...any reason for not using the ThreadPool?Franci Penov : Using thread pool threads for long running jobs can have implications on your app and the CLR performance.Harv : Reasons for not using the thread pool are described under "Limitations of Using the Thread Pool" http://www.beansoftware.com/ASP.NET-Tutorials/Multithreading-Thread-Pool.aspxSTW : The ThreadPool recycle's threads, there-by avoiding the overhead of creating new threads. As Franci says, the main reason to avoid it is for long-running background threads--in which case spawning a new thread will incur the initial overhead, but leave the pool threads free for short-job's to use.Henk Holterman : The OP mentions VS2005, aka C#2. So a lambda isn't helpful.KeeperOfTheSoul : Ah forgot that, changed to C# delegate syntax -
As mentioned in the other answers, you can use ThreadPool.QueueUserWorkItem to schedule your job on a thread in the thread pool or create a new explicit Thread instance for that work. You can read more about the various ways to create threads at the MSDN Threading Tutorial.
Which approach you use can have certain implications on the performance and behavior of your app and the CLR. For more details, read When to use thread pool in C#
-
Something simple like this ...
var threads = new List<Thread>(); var numThreads = 10; for( int i = 0; i < numThreads; i++ ) { threads.Add( new Thread( () => DoWork() ) ); threads[i].Name = i.ToString(); threads[i].Start(); }
0 comments:
Post a Comment