TryLockMutex()
Syntax
Result = TryLockMutex(Mutex)Description
Tries to lock the specified mutex. Unlike LockMutex(), this function does not stop execution until the mutex is available. It returns immediately and the return-value indicates if the lock was successful or not. This is useful in situations were the thread should not wait for the mutex to be available but rather do other things in the meantime.
Parameters
Mutex The mutex to lock.
Return value
Nonzero if the mutex was successfully locked, zero otherwise.
Remarks
If the lock was successful, the UnlockMutex() function must be called to make the mutex available to other threads again. If this is not done, this could easily lead to a lockup situation.
Example
Procedure ThreadProcedure(*Value)
Shared Mutex
Repeat
If TryLockMutex(Mutex)
PrintN("Mutex successfully locked.")
UnlockMutex(Mutex)
Break ; quit the loop and thread
Else
PrintN("Still waiting for mutex access...")
Delay(200)
EndIf
ForEver
EndProcedure
OpenConsole()
Mutex = CreateMutex()
LockMutex(Mutex) ; main program has the mutex locked at first
Thread = CreateThread(@ThreadProcedure(), 0)
Delay(4000)
UnlockMutex(Mutex) ; now release the mutex, so the thread can get it
Input()
See Also
UnlockMutex()
Supported OS
All