Orocos Real-Time Toolkit  2.9.0
Public Types | Public Member Functions | List of all members
RTT::internal::TsPool< T > Class Template Reference

A multi-reader multi-writer MemoryPool implementation. More...

#include <rtt/internal/rtt-internal-fwd.hpp>

Public Types

typedef T value_t
 
typedef unsigned int size_type
 

Public Member Functions

 TsPool (unsigned int ssize, const T &sample=T())
 Creates a fixed size memory pool holding ssize blocks of memory that can hold an object of class T. More...
 
 ~TsPool ()
 
void clear ()
 Clears all internal management data of this Memory Pool. More...
 
void data_sample (const T &sample)
 Initializes every element of the pool with the given sample and clears the pool. More...
 
value_tallocate ()
 
bool deallocate (T *Value)
 
unsigned int size ()
 Return the number of elements that are available to be allocated. More...
 
unsigned int capacity ()
 The maximum number of elements available for allocation. More...
 

Detailed Description

template<typename T>
class RTT::internal::TsPool< T >

A multi-reader multi-writer MemoryPool implementation.

It can hold max 65535 elements of type T.

Definition at line 168 of file rtt-internal-fwd.hpp.

Member Typedef Documentation

template<typename T>
typedef unsigned int RTT::internal::TsPool< T >::size_type

Definition at line 100 of file TsPool.hpp.

template<typename T>
typedef T RTT::internal::TsPool< T >::value_t

Definition at line 65 of file TsPool.hpp.

Constructor & Destructor Documentation

template<typename T>
RTT::internal::TsPool< T >::TsPool ( unsigned int  ssize,
const T &  sample = T() 
)
inline

Creates a fixed size memory pool holding ssize blocks of memory that can hold an object of class T.

Definition at line 105 of file TsPool.hpp.

template<typename T>
RTT::internal::TsPool< T >::~TsPool ( )
inline

Definition at line 112 of file TsPool.hpp.

Member Function Documentation

template<typename T>
value_t* RTT::internal::TsPool< T >::allocate ( )
inline
template<typename T>
unsigned int RTT::internal::TsPool< T >::capacity ( )
inline

The maximum number of elements available for allocation.

Returns
The maximum size.

Definition at line 222 of file TsPool.hpp.

template<typename T>
void RTT::internal::TsPool< T >::clear ( )
inline

Clears all internal management data of this Memory Pool.

All data blobs are considered to be owned by the pool again.

Definition at line 137 of file TsPool.hpp.

Referenced by RTT::internal::TsPool< Item >::data_sample().

template<typename T>
void RTT::internal::TsPool< T >::data_sample ( const T &  sample)
inline

Initializes every element of the pool with the given sample and clears the pool.

Definition at line 153 of file TsPool.hpp.

Referenced by RTT::base::BufferLockFree< T >::data_sample(), and RTT::internal::TsPool< Item >::TsPool().

template<typename T>
bool RTT::internal::TsPool< T >::deallocate ( T *  Value)
inline
template<typename T>
unsigned int RTT::internal::TsPool< T >::size ( )
inline

Return the number of elements that are available to be allocated.

This function is not thread-safe and should not be used when concurrent allocate()/deallocate() functions are running.

Returns
the number of elements left to allocate.

Definition at line 205 of file TsPool.hpp.

Referenced by RTT::internal::TsPool< Item >::~TsPool().


The documentation for this class was generated from the following files: