Suppose I have multiple threads blocking on a call to pthread_mutex_lock()
. When the mutex becomes available, does the first thread that called pthread_mutex_lock()
get the lock? That is, are calls to pthread_mutex_lock()
in FIFO order? If not, what, if any, order are they in? Thanks!
"If there are threads blocked on the mutex object referenced by mutex when pthread_mutex_unlock() is called, resulting in the mutex becoming available, the scheduling policy shall determine which thread shall acquire the mutex."
Aside from that, the answer to your question isn't specified by the POSIX standard. It may be random, or it may be in FIFO or LIFO or any other order, according to the choices made by the implementation.
When the mutex becomes available, does the first thread that called
pthread_mutex_lock()
get the lock?
No. One of the waiting threads gets a lock, but which one gets it is not determined.
FIFO order?
FIFO mutex is rather a pattern already. See Implementing a FIFO mutex in pthreads
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With