Is CountDownLatch affected by spurious wakeups?

让人想犯罪 __ 提交于 2019-12-12 10:35:13

问题


Concurrency management mechanisms such as wait/notify and lock/condition seem to be affected by spurious wakeups. Developers cater for those unexpected wakeups by re-checking that the condition has indeed changed.

When it comes to CountDownLatch, are spurious wakeups an issue?


回答1:


The javadoc of CountDownLatch#await() states

If the current count is greater than zero then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of two things happen:

  • The count reaches zero due to invocations of the countDown() method; or
  • Some other thread interrupts the current thread.

dormant meaning the method won't return. In other words, though a spurious wakeup can occur, it won't cause the await method to return.

You can look at the implementation to see how this is done exactly, but, in brief, it's the typical trick of looping and "waiting" (through LockSuport#park or Object#wait which are affected by spurious wakeups) until a condition is met.

When it comes to CountDownLatch, are spurious wakeups an issue?

No.




回答2:


The Object.wait/Condition.await methods are subject to "spurious wakeups".

The await method in CountDownLatch will wait until

  • The count reaches zero due to invocations of the countDown() method; or Some other thread interrupts the current thread; or The specified waiting time elapses.

So evenif spurious wakeup occurs, since the count has not reached,it wont return.

So the synchronizers like CountDownLatch, CyclicBarrier etc are not subject to spurious wakeups.



来源:https://stackoverflow.com/questions/31573955/is-countdownlatch-affected-by-spurious-wakeups

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!