Just right now I'm using following code to add queued threads. I don't like it. And my colleagues won't either because they don't know C# very well. All I want is of course to queue a method to be executed in a new thread.
private static void doStuff(string parameter)
{
// does stuff
}
// call (a)
ThreadPool.QueueUserWorkItem(a => doStuff("hello world"));
// call (b)
ThreadPool.QueueUserWorkItem(delegate { doStuff("hello world"); });
So are there other use variations of ThreadPool.QueueUserWorkItem
?
Best would be another 1-Line-Call. If possible with use of Func<>
or Action<>
.
EDIT: Got (b) from the answers and comments and I like it better already.
The answer for your question depends on how you design the application. Do you put it inside a common project ? you dont want to overhead a simple operations.
But, You could create a generic call for ThreadPool QueueUserItem that receive params, 1 param, 2 param, etc.. This is good instead of sending a simple string and be restricted.
This how you impl a parameters QueueUserItem with WaitCallback:
taken from C# Execute Method (with Parameters) with ThreadPool
And some links for ideas:
http://msdn.microsoft.com/en-us/library/4yd16hza.aspx
Generic ThreadPool in .NET
Difference between delegate.BeginInvoke and using ThreadPool threads in C#
What about this?
Or if you do not want to be signature restrictive and have a simple way of putting methods on a thread you can do it like this.For methods that do and do not return a value and have up to 6 parameters it would require you to define 12 overloads if I am not mistaken. It requires a bit more work up front, but is more simple to use.
I'm not entirely sure what kind of syntax you're looking for, but if you don't like the unused
a
in your example, why not useTask
instead?It doesn't really seem a lot better, but at least it doesn't have an unused identifier.
Note:
Task.Run()
is .Net 4.5 or later. If you're using .Net 4 you have to do:which isn't as short.
Both of the above do use the thread pool.
If you really must avoid using a lambda, you can use an anonymous delegate (which @nowhewhomustnotbenamed already mentioned):
But what's the point of that? It's much less readable!