Gray C++ Libraries  0.0.2
A set of C++ libraries for MSVC, GNU on Windows, WinCE, Linux
Gray::cThreadLockArraySmart< TYPE > Class Template Reference

#include <cThreadArray.h>

Inheritance diagram for Gray::cThreadLockArraySmart< TYPE >:
Gray::cArrayRef< TYPE > Gray::cArrayFacade< cRefPtr< TYPE >, TYPE * > Gray::cArrayTyped< TYPE, ARG_TYPE > Gray::CArray< TYPE, const TYPE & > Gray::CObject

Public Member Functions

 cThreadLockArraySmart ()
 
 ~cThreadLockArraySmart ()
 
ITERATE_t GetSize () const
 
cRefPtr< TYPEGetAtCheck (ITERATE_t nIndex) const
 
cRefPtr< TYPEPopHead ()
 
cRefPtr< TYPEPopTail ()
 
bool HasArg (TYPE *pObj) const
 
ITERATE_t Add (TYPE *pObj)
 
ITERATE_t AddTail (TYPE *pObj)
 
bool RemoveArg (TYPE *pObj)
 
void RemoveAll ()
 
void DisposeAll ()
 

Public Attributes

cThreadLockCount m_Lock
 

Additional Inherited Members

- Protected Types inherited from Gray::cArrayFacade< cRefPtr< TYPE >, TYPE * >
typedef cArrayTyped< cRefPtr< TYPE >, TYPE * > SUPER_t
 
typedef cArrayFacade< cRefPtr< TYPE >, TYPE * > THIS_t
 
typedef SUPER_t::ELEM_t ELEM_t
 
typedef SUPER_t::REF_t REF_t
 
- Protected Types inherited from Gray::cArrayTyped< TYPE, ARG_TYPE >
typedef CArray< TYPE, ARG_TYPE > SUPER_t
 
typedef cArrayTyped< TYPE, ARG_TYPE > THIS_t
 
typedef ITERATE_t iterator
 
typedef ITERATE_t const_iterator
 
typedef TYPE ELEM_t
 What type is stored. More...
 
typedef ARG_TYPE REF_t
 How to refer to this? value or ref or pointer? More...
 
- Protected Member Functions inherited from Gray::cArrayRef< TYPE >
void DisposeAll ()
 
- Protected Member Functions inherited from Gray::cArrayFacade< cRefPtr< TYPE >, TYPE * >
virtual ~cArrayFacade ()
 
virtual COMPARE_t CompareData (REF_t pData1, REF_t pData2) const noexcept override
 
REF_t GetAt (ITERATE_t index) const
 
REF_t GetAtCheck (ITERATE_t index) const
 
cRefPtr< TYPEPopHead ()
 
cRefPtr< TYPEPopTail ()
 
- Protected Member Functions inherited from Gray::cArrayTyped< TYPE, ARG_TYPE >
ITERATE_t QSortPartition (ITERATE_t iLeft, ITERATE_t iRight)
 
void QSort (ITERATE_t iLeft, ITERATE_t iRight)
 
 cArrayTyped () noexcept
 
 cArrayTyped (const THIS_t &rArray)
 
 cArrayTyped (ITERATE_t iSize)
 
virtual ~cArrayTyped ()
 
bool isValidCheck () const noexcept
 < memory allocation and structure definitions are valid. More...
 
bool IsValidIndex (ITERATE_t i) const noexcept
 
ITERATE_t ClampValidIndex (ITERATE_t i) const noexcept
 
size_t GetHeapStats (OUT ITERATE_t &iAllocCount) const noexcept
 
void AssertValidIndex (ITERATE_t nIndex) const
 
const TYPEGetAtSecure (ITERATE_t nIndex) const
 
TYPEElementAtSecure (ITERATE_t nIndex)
 
REF_t ConstElementAt (ITERATE_t nIndex) const
 
TYPEoperator[] (ITERATE_t nIndex)
 
const TYPEoperator[] (ITERATE_t nIndex) const
 
TYPEHead ()
 
TYPETail ()
 
TYPEElementAtHead ()
 
TYPEElementAtTail ()
 
REF_t ConstHead () const
 
REF_t ConstTail () const
 
REF_t GetAtTail ()
 
void UnLinkIndex (ITERATE_t nIndex)
 
void Swap (ITERATE_t i, ITERATE_t j)
 
void SetCopy (const cArrayTyped< TYPE, ARG_TYPE > &aValues)
 
const cArrayTyped< TYPE, ARG_TYPE > & operator= (const cArrayTyped< TYPE, ARG_TYPE > &aValues)
 
ITERATE_t FindIFor (ARG_TYPE arg) const
 
bool HasArg (ARG_TYPE arg) const
 
void RemoveLast ()
 
ELEM_t PopHead ()
 
ELEM_t PopTail ()
 
bool RemoveArg (ARG_TYPE arg)
 
void UnLinkArg (ARG_TYPE arg)
 
ITERATE_t AddTail (ARG_TYPE newElement)
 
ITERATE_t PushTail (ARG_TYPE newElement)
 
void AddHead (ARG_TYPE newElement)
 
TYPEget_DataWork () const
 
void AddArray (const SUPER_t &src)
 
bool IsEqualArray (const SUPER_t &aValues) const
 
bool isArraySorted () const
 
bool isArraySortedND () const
 
void QSort ()
 
- Protected Member Functions inherited from Gray::CArray< TYPE, const TYPE & >
bool IsValidIndex (ITERATE_t i) const noexcept
 
 CArray () noexcept
 
 CArray (THIS_t &&ref) noexcept
 
virtual ~CArray ()
 
bool IsValidMallocSize () const noexcept
 
ITERATE_t GetSize () const noexcept
 
ITERATE_t GetUpperBound () const noexcept
 
bool IsEmpty () const noexcept
 
void SetSize (ITERATE_t nNewSize)
 
ITERATE_t GetMallocSize () const noexcept
 
void RemoveAll ()
 Clean up. More...
 
const TYPEGetAt (ITERATE_t nIndex) const
 
TYPEElementAt (ITERATE_t nIndex)
 
void SetAt (ITERATE_t nIndex, const TYPE & newElement)
 
const TYPEGetData () const
 
TYPEGetData ()
 
void SetDataArrayPtr (TYPE *pData, ITERATE_t nSize)
 
void SetAtGrow (ITERATE_t nIndex, const TYPE & newElement)
 
ITERATE_t Add (const TYPE & newElement)
 
void Copy (const CArray &src)
 
TYPEoperator[] (ITERATE_t nIndex)
 
const TYPEoperator[] (ITERATE_t nIndex) const
 
void InsertAt (ITERATE_t nIndex, const TYPE & newElement)
 
void RemoveAt (ITERATE_t nIndex)
 
void RemoveAt (ITERATE_t nIndex, ITERATE_t iQty)
 
void MoveElement (ITERATE_t iFrom, ITERATE_t iTo)
 
- Protected Member Functions inherited from Gray::CObject
virtual ~CObject ()
 
virtual void AssertValid () const
 < memory allocation and structure definitions are valid. More...
 
virtual void Serialize (cArchive &a)
 
- Protected Attributes inherited from Gray::CArray< TYPE, const TYPE & >
TYPEm_pData
 the actual array of data More...
 
ITERATE_t m_nSize
 Number of elements (upperBound - 1) More...
 

Detailed Description

template<class TYPE>
class Gray::cThreadLockArraySmart< TYPE >

Thread safe array of smart pointers. NON sorted.

Constructor & Destructor Documentation

◆ cThreadLockArraySmart()

template<class TYPE >
Gray::cThreadLockArraySmart< TYPE >::cThreadLockArraySmart ( )
inline

◆ ~cThreadLockArraySmart()

template<class TYPE >
Gray::cThreadLockArraySmart< TYPE >::~cThreadLockArraySmart ( )
inline

Member Function Documentation

◆ Add()

template<class TYPE >
ITERATE_t Gray::cThreadLockArraySmart< TYPE >::Add ( TYPE pObj)
inline

◆ AddTail()

template<class TYPE >
ITERATE_t Gray::cThreadLockArraySmart< TYPE >::AddTail ( TYPE pObj)
inline

◆ DisposeAll()

template<class TYPE >
void Gray::cThreadLockArraySmart< TYPE >::DisposeAll ( void  )
inline

ASSUME TYPE supports DisposeThis(); like cXObject

◆ GetAtCheck()

template<class TYPE >
cRefPtr<TYPE> Gray::cThreadLockArraySmart< TYPE >::GetAtCheck ( ITERATE_t  nIndex) const
inline
Note
Its slightly dangerous to enum a thread used list. We could read the same entry 2 times !
NEVER NEVER lock the list and the object at the same time! This could create a permanent deadlock!

◆ GetSize()

template<class TYPE >
ITERATE_t Gray::cThreadLockArraySmart< TYPE >::GetSize ( ) const
inline

Used for statistical purposes. This may change of course.

◆ HasArg()

template<class TYPE >
bool Gray::cThreadLockArraySmart< TYPE >::HasArg ( TYPE pObj) const
inline

Find a specified entry.

◆ PopHead()

template<class TYPE >
cRefPtr<TYPE> Gray::cThreadLockArraySmart< TYPE >::PopHead ( )
inline

◆ PopTail()

template<class TYPE >
cRefPtr<TYPE> Gray::cThreadLockArraySmart< TYPE >::PopTail ( )
inline

◆ RemoveAll()

template<class TYPE >
void Gray::cThreadLockArraySmart< TYPE >::RemoveAll ( )
inline

◆ RemoveArg()

template<class TYPE >
bool Gray::cThreadLockArraySmart< TYPE >::RemoveArg ( TYPE pObj)
inline
Returns
true = removed. false = was not here.

Member Data Documentation

◆ m_Lock

template<class TYPE >
cThreadLockCount Gray::cThreadLockArraySmart< TYPE >::m_Lock
mutable

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