Thread Handles and Identifiers
When a new thread is created by the
CreateThread or
CreateRemoteThread function, a handle of the thread is returned. By default, this handle has
full access rights, and

subject to security access checking

can be used in any of the functions that accept a thread handle. This handle
can be inherited by child processes, depending on the inheritance flag
specified when it is created. The handle can be duplicated by
DuplicateHandle, which enables you to create a thread handle with a subset of the access
rights. The handle is valid until closed, even after the thread it represents has
been terminated.
The
CreateThread and
CreateRemoteThread functions also return an identifier that uniquely identifies the thread
throughout the system. A thread can use the
GetCurrentThreadId function to get its own thread identifier. The identifiers are valid from the
time the thread is created until the thread has been terminated.
The Win32 API does not provide a way to get the thread handle from the thread
identifier. If the handles were made available this way, the owning process
could fail because another process unexpectedly performed an operation on one of
its threads, such as suspending it, resuming it, adjusting its priority, or
terminating it. Instead, you must request the handle from the thread creator or the
thread itself.
A thread can use the
GetCurrentThread function to retrieve a
pseudo handle to its own thread object. This pseudo handle is valid only for the calling
process; it cannot be inherited or duplicated for use by other processes. To get
the real handle to the thread, given a pseudo handle, use the
DuplicateHandle function.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples