Home | All Classes | Main Classes | Annotated | Grouped Classes | Functions

TQThreadStorage Class Reference

The TQThreadStorage class provides per-thread data storage. More...

All the functions in this class are thread-safe when TQt is built with thread support.

#include <qthreadstorage.h>

List of all member functions.

Public Members


Detailed Description

The TQThreadStorage class provides per-thread data storage.

TQThreadStorage is a template class that provides per-thread data storage.

Note that due to compiler limitations, TQThreadStorage can only store pointers.

The setLocalData() function stores a single thread-specific value for the calling thread. The data can be accessed later using the localData() functions. TQThreadStorage 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).

The hasLocalData() function allows the programmer to determine if data has previously been set using the setLocalData() function. This is useful for lazy initializiation.

For example, the following code uses TQThreadStorage 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 (either normally or via termination).

    TQThreadStorage<TQCache<SomeClass> *> caches;

    void cacheObject( const TQString &key, SomeClass *object )
    {
        if ( ! caches.hasLocalData() )
            caches.setLocalData( new TQCache<SomeClass> );

        caches.localData()->insert( key, object );
    }

    void removeFromCache( const TQString &key )
    {
        if ( ! caches.hasLocalData() )
            return; // nothing to do

        caches.localData()->remove( key );
    }
    

Caveats

See also Environment Classes and Threading.


Member Function Documentation

TQThreadStorage::TQThreadStorage ()

Constructs a new per-thread data storage object.

TQThreadStorage::~TQThreadStorage ()

Destroys the per-thread data storage object.

Note: The per-thread data stored is not deleted. Any data left in TQThreadStorage is leaked. Make sure that all threads using TQThreadStorage have exited before deleting the TQThreadStorage.

See also hasLocalData().

bool TQThreadStorage::hasLocalData () const

Returns TRUE if the calling thread has non-zero data available; otherwise returns FALSE.

See also localData().

T & TQThreadStorage::localData ()

Returns a reference to the data that was set by the calling thread.

Note: TQThreadStorage can only store pointers. This function returns a reference to the pointer that was set by the calling thread. The value of this reference is 0 if no data was set by the calling thread,

See also hasLocalData().

T TQThreadStorage::localData () const

This is an overloaded member function, provided for convenience. It behaves essentially like the above function.

Returns a copy of the data that was set by the calling thread.

Note: TQThreadStorage can only store pointers. This function returns a pointer to the data that was set by the calling thread. If no data was set by the calling thread, this function returns 0.

See also hasLocalData().

void TQThreadStorage::setLocalData ( T data )

Sets the local data for the calling thread to data. It can be accessed later using the localData() functions.

If data is 0, this function deletes the previous data (if any) and returns immediately.

If data is non-zero, TQThreadStorage 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.

Note: TQThreadStorage can only store pointers. The data argument must be either a pointer to an object created on the heap (i.e. using new) or 0. You should not delete data yourself; TQThreadStorage takes ownership and will delete the data itself.

See also localData() and hasLocalData().


This file is part of the TQt toolkit. Copyright © 1995-2007 Trolltech. All Rights Reserved.


Copyright © 2007 TrolltechTrademarks
TQt 3.3.8