safe check if lockfree::queue is empty
data:image/s3,"s3://crabby-images/588e6/588e6a139fcfd8a626054d2512e68211261d5c8a" alt=""
Hi, I read the docs about lockfree::queue::empty() and understang what this way is not safe in multithreaded program. The question is, how can I verify that the queue is empty? Will it be correct the following code? bool empty() { T *tmp = 0; if ( queue.pop(tmp) ) { queue.push(tmp); return false; } return true; } Thanks. -- Regards, niXman ___________________________________________________ Dual-target(32 & 64-bit) MinGW compilers for 32 and 64-bit Windows: http://sourceforge.net/projects/mingwbuilds/ ___________________________________________________ Another online IDE: http://liveworkspace.org/
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG On 04/02/2013 03:45 AM, niXman wrote:
Hi,
I read the docs about lockfree::queue::empty() and understang what this way is not safe in multithreaded program. The question is, how can I verify that the queue is empty?
It's impossible. The problem is that by the time you use the answer, the state of the queue may have changed. You can't do better than the built in empty.
Will it be correct the following code?
No. It will re-order the elements if there is more than one.
bool empty() { T *tmp = 0; if ( queue.pop(tmp) ) { queue.push(tmp); return false; } return true; }
In Christ, Steven Watanabe
participants (2)
-
niXman
-
Steven Watanabe