forked from eden-emu/eden
		
	threadsafe_queue: Remove NeedSize template parameter
The necessity of this parameter is dubious at best, and in 2019 probably offers completely negligible savings as opposed to just leaving this enabled. This removes it and simplifies the overall interface.
This commit is contained in:
		
					parent
					
						
							
								a67aca0ef2
							
						
					
				
			
			
				commit
				
					
						eb39267bc0
					
				
			
		
					 2 changed files with 13 additions and 15 deletions
				
			
		|  | @ -14,10 +14,10 @@ | |||
| #include "common/common_types.h" | ||||
| 
 | ||||
| namespace Common { | ||||
| template <typename T, bool NeedSize = true> | ||||
| template <typename T> | ||||
| class SPSCQueue { | ||||
| public: | ||||
|     SPSCQueue() : size(0) { | ||||
|     SPSCQueue() { | ||||
|         write_ptr = read_ptr = new ElementPtr(); | ||||
|     } | ||||
|     ~SPSCQueue() { | ||||
|  | @ -26,12 +26,11 @@ public: | |||
|     } | ||||
| 
 | ||||
|     u32 Size() const { | ||||
|         static_assert(NeedSize, "using Size() on FifoQueue without NeedSize"); | ||||
|         return size.load(); | ||||
|     } | ||||
| 
 | ||||
|     bool Empty() const { | ||||
|         return !read_ptr->next.load(); | ||||
|         return Size() == 0; | ||||
|     } | ||||
| 
 | ||||
|     T& Front() const { | ||||
|  | @ -47,13 +46,13 @@ public: | |||
|         ElementPtr* new_ptr = new ElementPtr(); | ||||
|         write_ptr->next.store(new_ptr, std::memory_order_release); | ||||
|         write_ptr = new_ptr; | ||||
|         if (NeedSize) | ||||
|             size++; | ||||
| 
 | ||||
|         ++size; | ||||
|     } | ||||
| 
 | ||||
|     void Pop() { | ||||
|         if (NeedSize) | ||||
|             size--; | ||||
|         --size; | ||||
| 
 | ||||
|         ElementPtr* tmpptr = read_ptr; | ||||
|         // advance the read pointer
 | ||||
|         read_ptr = tmpptr->next.load(); | ||||
|  | @ -66,8 +65,7 @@ public: | |||
|         if (Empty()) | ||||
|             return false; | ||||
| 
 | ||||
|         if (NeedSize) | ||||
|             size--; | ||||
|         --size; | ||||
| 
 | ||||
|         ElementPtr* tmpptr = read_ptr; | ||||
|         read_ptr = tmpptr->next.load(std::memory_order_acquire); | ||||
|  | @ -103,13 +101,13 @@ private: | |||
| 
 | ||||
|     ElementPtr* write_ptr; | ||||
|     ElementPtr* read_ptr; | ||||
|     std::atomic<u32> size; | ||||
|     std::atomic<u32> size{0}; | ||||
| }; | ||||
| 
 | ||||
| // a simple thread-safe,
 | ||||
| // single reader, multiple writer queue
 | ||||
| 
 | ||||
| template <typename T, bool NeedSize = true> | ||||
| template <typename T> | ||||
| class MPSCQueue { | ||||
| public: | ||||
|     u32 Size() const { | ||||
|  | @ -144,7 +142,7 @@ public: | |||
|     } | ||||
| 
 | ||||
| private: | ||||
|     SPSCQueue<T, NeedSize> spsc_queue; | ||||
|     SPSCQueue<T> spsc_queue; | ||||
|     std::mutex write_lock; | ||||
| }; | ||||
| } // namespace Common
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
				Lioncash