File was renamed from squeue/include/QFactory.h |
| | |
| | | #include "usg_common.h" |
| | | #include "mm.h" |
| | | #include "hashtable.h" |
| | | #include "SArrayLockFreeQueue.h" |
| | | #include "lock_free_queue.h" |
| | | #include "SLinkedLockFreeQueue.h" |
| | | |
| | | namespace QFactory{ |
| | | |
| | | |
| | | |
| | | namespace QueueFactory{ |
| | | |
| | | template <typename T> |
| | | SLinkedLockFreeQueue<T>* createLinkedLockFreeQueue(int key, size_t size) { |
| | |
| | | |
| | | |
| | | template <typename T> |
| | | SArrayLockFreeQueue<T>* createArrayLockFreeQueue(int key, size_t size) { |
| | | LockFreeQueue<T>* createArrayLockFreeQueue(int key, size_t size=16) { |
| | | hashtable_t *hashtable; |
| | | SArrayLockFreeQueue<T> *queue; |
| | | LockFreeQueue<T> *queue; |
| | | int first; |
| | | |
| | | first = mm_init(sizeof(hashtable_t), (void **)&hashtable); |
| | | |
| | | if (first) |
| | | hashtable_init(hashtable);; |
| | | |
| | | if ((queue = (SArrayLockFreeQueue<T> *)hashtable_get(hashtable, key)) == NULL ) { |
| | | queue = new SArrayLockFreeQueue <T>(size); |
| | | //LockFreeQueue<int, 10000> q; |
| | | if ((queue = (LockFreeQueue<T> *)hashtable_get(hashtable, key)) == NULL ) { |
| | | queue = new LockFreeQueue<T>(size); |
| | | hashtable_put(hashtable, key, (void *)queue); |
| | | } |
| | | |
| | |
| | | |
| | | |
| | | template <typename T> |
| | | SAbstractQueue<T>* createQueue(int key, size_t size) { |
| | | return QFactory::createLinkedLockFreeQueue<T>(key, size); |
| | | LockFreeQueue<T>* createQueue(int key, size_t size) { |
| | | return QueueFactory::createArrayLockFreeQueue<T>(key, size); |
| | | } |
| | | |
| | | } |