views:

102

answers:

3

MSDN, as well as many other sources, claim that worker threads in the thread pool are always background.

"Thread pool threads are background threads." (MSDN)

"Pooled threads are always background threads." (Threading in C#, Joseph Albahari)

I can easily make the worker thread non-background by setting

Thread.CurrentThread.IsBackground = false;

And the application will be waiting until the thread finishes.

What's wrong with that?

+5  A: 

Yes, you can change them. But you should not.

For the same reasons you don't repaint a borrowed car. Same for other thread properties like priority and MTA.

If you want a different kind of thread, create your own.

Henk Holterman
+3  A: 

When does the thread finish? When your method ends? I highly doubt that's the case. The whole point of the thread pool is that once your thread is finished, it gets put back in the pool to be reused. Now you've let go of a thread, it's gone back into the thread pool and your application is still running because it's a foreground thread. There's no way to get that thread back out to kill it.

Hounshell
Thank you. I understand problems caused by making pooled thread non-background. My point is why the Framework doesn't disallow doing this in more obvious way? I expected an exception to be honest. Anyway, thank you.
Dmitry Karpezo
+1  A: 

Thread pool threads are background threads

Finish that sentence with "they have their IsBackground property initialized to True, unlike threads created with the Thread class."

Setting it to false could be a bit risky. Threadpool threads are recycled, I'm not so sure that the property will be re-initialized. It is not a property associated with the physical operating system thread, they don't have IsBackground behavior, it is added by the wrapper that the CLR puts around it. So probably yes. Little reason to mess with it though.

Hans Passant