System.Threading.ThreadState Enumeration

Specifies the execution states of a System.Threading.Thread.

Syntax

[System.Flags]
[System.Runtime.InteropServices.ComVisible(true)]
public enum ThreadState

Remarks

The System.Threading.ThreadState enumeration is of interest only in a few debugging scenarios. Your code should never use the thread state to synchronize the activities of threads.

System.Threading.ThreadState defines a set of all possible execution states for threads. Once a thread is created, it is in at least one of the states until it terminates. Threads created within the common language runtime are initially in the Unstarted state, while external threads that come into the runtime are already in the Running state. An Unstarted thread is transitioned into the Running state by calling Thread.Start. Not all combinations of ThreadState values are valid; for example, a thread cannot be in both the Aborted and Unstarted states.

Note:

There are two thread state enumerations, System.Threading.ThreadState and System.Diagnostics.ThreadState.

The following table shows the actions that cause a change of state.

A thread is created within the common language runtime.

Unstarted

Another thread calls the Thread.Start method on the new thread, and the call returns.

The Thread.Start method does not return until the new thread has started running. There is no way to know at what point the new thread will start running, during the call to Thread.Start.

Running

The thread calls Thread.Sleep(int)

WaitSleepJoin

The thread calls Monitor.Wait(object, int, bool) on another object.

WaitSleepJoin

The thread calls Thread.Join on another thread.

WaitSleepJoin

Another thread calls Thread.Interrupt

Running

Another thread calls Thread.Suspend

SuspendRequested

The thread responds to a Thread.Suspend request.

Suspended

Another thread calls Thread.Resume

Running

Another thread calls Thread.Abort(object)

AbortRequested

The thread responds to a Thread.Abort(object) request.

Stopped

A thread is terminated.

Stopped

In addition to the states noted above, there is also the Background state, which indicates whether the thread is running in the background or foreground.

A thread can be in more than one state at a given time. For example, if a thread is blocked on a call to Monitor.Wait(object, int, bool), and another thread calls Thread.Abort(object) on the blocked thread, the blocked thread will be in both the WaitSleepJoin and the AbortRequested states at the same time. In this case, as soon as the thread returns from the call to Monitor.Wait(object, int, bool) or is interrupted, it will receive the System.Threading.ThreadAbortException to begin aborting.

The Thread.ThreadState property of a thread provides the current state of a thread. Applications must use a bitmask to determine whether a thread is running. Since the value for Running is zero (0), test whether a thread is running by using C# code such as (myThread.ThreadState & (ThreadState.Stopped | ThreadState.Unstarted)) == 0 or Visual Basic code such as (myThread.ThreadState And (ThreadState.Stopped Or ThreadState.Unstarted)) = 0.

Members

Member NameDescription
Aborted

The thread state includes ThreadState.AbortRequested and the thread is now dead, but its state has not yet changed to ThreadState.Stopped.

AbortRequested

The Thread.Abort(object) method has been invoked on the thread, but the thread has not yet received the pending System.Threading.ThreadAbortException that will attempt to terminate it.

Background

The thread is being executed as a background thread, as opposed to a foreground thread. This state is controlled by setting the Thread.IsBackground property.

Running

The thread has been started, it is not blocked, and there is no pending System.Threading.ThreadAbortException.

Stopped

The thread has stopped.

StopRequested

The thread is being requested to stop. This is for internal use only.

Suspended

The thread has been suspended.

SuspendRequested

The thread is being requested to suspend.

Unstarted

The Thread.Start method has not been invoked on the thread.

WaitSleepJoin

The thread is blocked. This could be the result of calling Thread.Sleep(int) or Thread.Join, of requesting a lock — for example, by calling Monitor.Enter(object) or Monitor.Wait(object, int, bool) — or of waiting on a thread synchronization object such as System.Threading.ManualResetEvent.

Requirements

Namespace: System.Threading
Assembly: mscorlib (in mscorlib.dll)
Assembly Versions: 1.0.5000.0, 2.0.0.0, 4.0.0.0