Scenario 1: release mutex then wait
Scenario 2: wait and then release mutex
Trying to understand conceptually what it does.
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
If the mutex were released before the calling thread is considered “blocked” on the condition variable, then another thread could lock the mutex, change the state that the predicate is based on, and call
pthread_cond_signalwithout the waiting thread ever waking up (since it’s not yet blocked). That’s the problem.Scenario 2, waiting then releasing the mutex, is internally how any real-world implementation has to work, since there’s no such thing as an atomic implementation of the necessary behavior. But from the application’s perspective, there’s no way to observe the thread being part of the blocked set without the mutex also being released, so in the sense of the “abstract machine”, it’s atomic.
Edit: To go into more detail, the real-world implementation of a condition variable wait generally looks like:
Thus, the act of “blocking” is split between two steps, one of which happens before the mutex is unlocked (gaining membership in the blocked set) and the other of which happens after the mutex is unlocked (possibly sleeping and yielding control to other threads). It’s this split that’s able to make the “condition wait” operation “atomic” in the abstract machine.