#include <nng/nng.h>
#include <nng/supplemental/util/platform.h>
void nng_mtx_lock(nng_mtx *mtx);
The nng_mtx_lock()
acquires exclusive ownership of the mutex mtx.
If the lock is already owned, this function will wait until the current
owner releases it with nng_mtx_unlock()
.
If multiple threads are waiting for the lock, the order of acquisition is not specified.
Note
|
A mutex can only be unlocked by the thread that locked it. |
Important
|
Mutex locks are not recursive; attempts to reacquire the same mutex may result in deadlock or aborting the current program. It is a programming error for the owner of a mutex to attempt to reacquire it. |
NNG offers neither a non-blocking variant that can fail, nor recursive mutexes. This is by design, as NNG itself does not use such things, and most often the need for them is the result of poor design. If such capabilities are needed, they may be synthesized fairly easily from mutexes and condition variables.