![]() |
Qt 6.x
The Qt SDK
|
\inmodule QtCore More...
#include <qthreadstorage.h>
Public Member Functions | |
QThreadStorage ()=default | |
Constructs a new per-thread data storage object. | |
~QThreadStorage ()=default | |
Destroys the per-thread data storage object. | |
QThreadStorage (const QThreadStorage &rhs)=delete | |
QThreadStorage & | operator= (const QThreadStorage &rhs)=delete |
bool | hasLocalData () const |
If T is a pointer type, returns true if the calling thread has non-zero data available. | |
T & | localData () |
Returns a reference to the data that was set by the calling thread. | |
T | localData () const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns a copy of the data that was set by the calling thread. | |
void | setLocalData (T t) |
Sets the local data for the calling thread to data. | |
\inmodule QtCore
The QThreadStorage class provides per-thread data storage.
\threadsafe
QThreadStorage is a template class that provides per-thread data storage.
The setLocalData() function stores a single thread-specific value for the calling thread. The data can be accessed later using localData().
The hasLocalData() function allows the programmer to determine if data has previously been set using the setLocalData() function. This is also useful for lazy initialization.
If T is a pointer type, QThreadStorage takes ownership of the data (which must be created on the heap with new
) and deletes it when the thread exits, either normally or via termination.
For example, the following code uses QThreadStorage to store a single cache for each thread that calls the cacheObject() and removeFromCache() functions. The cache is automatically deleted when the calling thread exits.
Definition at line 153 of file qthreadstorage.h.
|
default |
Constructs a new per-thread data storage object.
|
default |
Destroys the per-thread data storage object.
Note: The per-thread data stored is not deleted. Any data left in QThreadStorage is leaked. Make sure that all threads using QThreadStorage have exited before deleting the QThreadStorage.
|
delete |
|
inline |
If T is a pointer type, returns true
if the calling thread has non-zero data available.
If T is a value type, returns whether the data has already been constructed by calling setLocalData or localData.
Definition at line 173 of file qthreadstorage.h.
References qThreadStorage_hasLocalData().
Referenced by QHttpThreadDelegate::~QHttpThreadDelegate(), and QHttpThreadDelegate::startRequest().
|
inline |
Returns a reference to the data that was set by the calling thread.
If no data has been set, this will create a default constructed instance of type T.
Definition at line 178 of file qthreadstorage.h.
Referenced by QHttpThreadDelegate::~QHttpThreadDelegate(), QCtfLibImpl::doTracepoint(), QOpenGLEngineThreadStorage::engine(), QOpenGLShaderStorage::shadersForThread(), QHttpThreadDelegate::startRequest(), and QHttpThreadDelegate::startRequestSynchronously().
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns a copy of the data that was set by the calling thread.
Definition at line 185 of file qthreadstorage.h.
|
delete |
|
inline |
Sets the local data for the calling thread to data.
It can be accessed later using the localData() functions.
If T is a pointer type, QThreadStorage takes ownership of the data and deletes it automatically either when the thread exits (either normally or via termination) or when setLocalData() is called again.
Definition at line 190 of file qthreadstorage.h.
Referenced by QHttpThreadDelegate::startRequest(), and QHttpThreadDelegate::startRequestSynchronously().