the whole game
This commit is contained in:
143
project/lib_projects/raknet/jni/RaknetSources/DS_ThreadsafeAllocatingQueue.h
Executable file
143
project/lib_projects/raknet/jni/RaknetSources/DS_ThreadsafeAllocatingQueue.h
Executable file
@@ -0,0 +1,143 @@
|
||||
/// \file DS_ThreadsafeAllocatingQueue.h
|
||||
/// \internal
|
||||
/// A threadsafe queue, that also uses a memory pool for allocation
|
||||
|
||||
#ifndef __THREADSAFE_ALLOCATING_QUEUE
|
||||
#define __THREADSAFE_ALLOCATING_QUEUE
|
||||
|
||||
#include "DS_Queue.h"
|
||||
#include "SimpleMutex.h"
|
||||
#include "DS_MemoryPool.h"
|
||||
|
||||
// #if defined(new)
|
||||
// #pragma push_macro("new")
|
||||
// #undef new
|
||||
// #define RMO_NEW_UNDEF_ALLOCATING_QUEUE
|
||||
// #endif
|
||||
|
||||
namespace DataStructures
|
||||
{
|
||||
|
||||
template <class structureType>
|
||||
class RAK_DLL_EXPORT ThreadsafeAllocatingQueue
|
||||
{
|
||||
public:
|
||||
// Queue operations
|
||||
void Push(structureType *s);
|
||||
structureType *PopInaccurate(void);
|
||||
structureType *Pop(void);
|
||||
void SetPageSize(int size);
|
||||
bool IsEmpty(void);
|
||||
|
||||
// Memory pool operations
|
||||
structureType *Allocate(const char *file, unsigned int line);
|
||||
void Deallocate(structureType *s, const char *file, unsigned int line);
|
||||
void Clear(const char *file, unsigned int line);
|
||||
protected:
|
||||
|
||||
MemoryPool<structureType> memoryPool;
|
||||
RakNet::SimpleMutex memoryPoolMutex;
|
||||
Queue<structureType*> queue;
|
||||
RakNet::SimpleMutex queueMutex;
|
||||
};
|
||||
|
||||
template <class structureType>
|
||||
void ThreadsafeAllocatingQueue<structureType>::Push(structureType *s)
|
||||
{
|
||||
queueMutex.Lock();
|
||||
queue.Push(s, _FILE_AND_LINE_ );
|
||||
queueMutex.Unlock();
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
structureType *ThreadsafeAllocatingQueue<structureType>::PopInaccurate(void)
|
||||
{
|
||||
structureType *s;
|
||||
if (queue.IsEmpty())
|
||||
return 0;
|
||||
queueMutex.Lock();
|
||||
if (queue.IsEmpty()==false)
|
||||
s=queue.Pop();
|
||||
else
|
||||
s=0;
|
||||
queueMutex.Unlock();
|
||||
return s;
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
structureType *ThreadsafeAllocatingQueue<structureType>::Pop(void)
|
||||
{
|
||||
structureType *s;
|
||||
queueMutex.Lock();
|
||||
if (queue.IsEmpty())
|
||||
{
|
||||
queueMutex.Unlock();
|
||||
return 0;
|
||||
}
|
||||
s=queue.Pop();
|
||||
queueMutex.Unlock();
|
||||
return s;
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
structureType *ThreadsafeAllocatingQueue<structureType>::Allocate(const char *file, unsigned int line)
|
||||
{
|
||||
structureType *s;
|
||||
memoryPoolMutex.Lock();
|
||||
s=memoryPool.Allocate(file, line);
|
||||
memoryPoolMutex.Unlock();
|
||||
// Call new operator, memoryPool doesn't do this
|
||||
s = new ((void*)s) structureType;
|
||||
return s;
|
||||
}
|
||||
template <class structureType>
|
||||
void ThreadsafeAllocatingQueue<structureType>::Deallocate(structureType *s, const char *file, unsigned int line)
|
||||
{
|
||||
// Call delete operator, memory pool doesn't do this
|
||||
s->~structureType();
|
||||
memoryPoolMutex.Lock();
|
||||
memoryPool.Release(s, file, line);
|
||||
memoryPoolMutex.Unlock();
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
void ThreadsafeAllocatingQueue<structureType>::Clear(const char *file, unsigned int line)
|
||||
{
|
||||
memoryPoolMutex.Lock();
|
||||
for (unsigned int i=0; i < queue.Size(); i++)
|
||||
{
|
||||
queue[i]->~structureType();
|
||||
memoryPool.Release(queue[i], file, line);
|
||||
}
|
||||
queue.Clear(file, line);
|
||||
memoryPoolMutex.Unlock();
|
||||
memoryPoolMutex.Lock();
|
||||
memoryPool.Clear(file, line);
|
||||
memoryPoolMutex.Unlock();
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
void ThreadsafeAllocatingQueue<structureType>::SetPageSize(int size)
|
||||
{
|
||||
memoryPool.SetPageSize(size);
|
||||
}
|
||||
|
||||
template <class structureType>
|
||||
bool ThreadsafeAllocatingQueue<structureType>::IsEmpty(void)
|
||||
{
|
||||
bool isEmpty;
|
||||
queueMutex.Lock();
|
||||
isEmpty=queue.IsEmpty();
|
||||
queueMutex.Unlock();
|
||||
return isEmpty;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
|
||||
// #if defined(RMO_NEW_UNDEF_ALLOCATING_QUEUE)
|
||||
// #pragma pop_macro("new")
|
||||
// #undef RMO_NEW_UNDEF_ALLOCATING_QUEUE
|
||||
// #endif
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user