Thread Local Storage
All threads of a process share the virtual address space and the global
variables of that process. The local variables of a thread function are local to each
thread that runs the function. However, the static or global variables used by
that function have the same value for all threads. With thread local storage
(TLS), you can create a unique copy of a variable for each thread. Using TLS,
one thread allocates an index that can be used by any thread of the process to
retrieve its unique copy.
Use the following steps to implement TLS:
- Use the TlsAlloc function during process or dynamic-link library (DLL) initialization to
allocate a TLS index.
- For each thread that needs to use the TLS index, allocate dynamic storage,
then use the TlsSetValue function to associate the index with a pointer to the dynamic storage.
- When you need a thread to access its storage, specify the TLS index in a call
to the TlsGetValue function to retrieve the pointer.
- When each thread no longer needs the dynamic storage that it has associated
with a TLS index, it must free the index. When all threads have finished using a
TLS index, use the TlsFree function to free the index.
The constant TLS_MINIMUM_AVAILABLE defines the minimum number of TLS indexes
available in each process. This minimum is guaranteed to be at least 64 for all
It is ideal to use TLS in a DLL. Perform the initial TLS operations in the DllEntryPoint
function in the context of the process or thread attaching to the DLL. When a
new process attaches to the DLL, call TlsAlloc
in the entry-point function to allocate a TLS index for that process. Then
store the TLS index in a global variable that is private to each attached
process. When a new thread attaches to the DLL, allocate dynamic memory for that
thread in the entry-point function, and use TlsSetValue
with the TLS index from TlsAlloc
to save private data to the index. Then you can use the TLS index in a call
to access the private data for the calling thread from within any function in
the DLL. When a process detaches from the DLL, call TlsFree
For an example illustrating the use of thread local storage, see Using Thread Local Storage
- Software for developers
Software for Android Developers
- More information resources
Unix Manual Pages
- Databases for Amazon shops developers
Amazon Categories Database
Browse Nodes Database