I have a consumer and a producer that adds and deletes Item objects from the queue. If I use the put()
and take()
methods. Is there any thread safety issues I need to still cover? This is similar to the bounded buffer problem and I was just wondering if using the blocking queue instead replaces the need for semaphores or monitors. The Item object itself would probably need synchronization (setters but getters don't need lock), am I right? And lastly, I'm not quite sure how to test if it is thread safe since I can't simultaneously make both threads call the take()
because to order of execution is underterministic. Any ideas? Thanks.
8
votes
2 Answers
7
votes
It is perfectly thread-safe for what you're doing, in fact this is what it's designed for. The description of BlockingQueue
(which is the interface implemented by LinkedBlockingQueue
) states:
BlockingQueue implementations are thread-safe. All queuing methods achieve their effects atomically using internal locks or other forms of concurrency control.
1
votes
Simultaneous put() and take() are not thread-safe since they use 2 different locks.
This is already answered here : Are LinkedBlockingQueue's insert and remove methods thread safe?
put()
don't appear, or the same item item shows up repeatedly in the results fromtake()
? – michel-slm