| glibmm
    2.38.0
    | 
Thread-local data pointer. More...
#include <glibmm/threads.h>
| Public Types | |
| typedef void(* | DestructorFunc )(void*) | 
| Public Member Functions | |
| Private (DestructorFunc destructor_func=&Private< T >::delete_ptr) | |
| Constructor.  More... | |
| T* | get () | 
| Gets the pointer stored in the calling thread.  More... | |
| void | set (T* data) | 
| Sets the pointer in the calling thread without calling destructor_func().  More... | |
| void | replace (T* data) | 
| Sets the pointer in the calling thread and calls destructor_func().  More... | |
| GPrivate* | gobj () | 
| Static Public Member Functions | |
| static void | delete_ptr (void* data) | 
| Deletes static_cast<T*>(data)  More... | |
Thread-local data pointer.
It is recommended that all instances of this class are statically allocated. The first time an instance is used (get(), set() or replace() is called) gtk+ allocates a scarce OS resource that cannot be deallocated.
| typedef void(* Glib::Threads::Private< T >::DestructorFunc)(void*) | 
| 
 | inlineexplicit | 
Constructor.
| destructor_func | Function pointer, or 0. If destructor_func is not 0 and the stored data pointer is not 0, this function is called when replace() is called and when the thread exits. | 
| 
 | static | 
Deletes static_cast<T*>(data)
| 
 | inline | 
Gets the pointer stored in the calling thread.
| 
 | inline | 
| 
 | inline | 
Sets the pointer in the calling thread and calls destructor_func(). 
If a function pointer (and not 0) was specified in the constructor, and the stored data pointer before the call to replace() is not 0, then destructor_func() is called with this old pointer value.
| 
 | inline | 
Sets the pointer in the calling thread without calling destructor_func(). 
 1.8.3.1
 1.8.3.1