In a situation where the lock is already held by the thread calling try_lock, the two implementations have the opposite semantics.
Windows:
inline bool os::PlatformMutex::try_lock() {
return TryEnterCriticalSection(&_mutex);
}
"If the critical section is successfully entered or the current thread already owns the critical section, the return value is nonzero.
If another thread already owns the critical section, the return value is zero."
Posix:
inline bool os::PlatformMutex::try_lock() {
int status = pthread_mutex_trylock(mutex());
assert_status(status == 0 || status == EBUSY, status, "mutex_trylock");
return status == 0;
}
"The pthread_mutex_trylock() function shall be equivalent to pthread_mutex_lock(), except that if the mutex object referenced by mutex is currently locked (by any thread, including the current thread), the call shall return immediately."
and:
"[EDEADLK]
A deadlock condition was detected or the current thread already owns the mutex."
This difference propagates up to the Mutex::try_lock implementation.
Windows:
inline bool os::PlatformMutex::try_lock() {
return TryEnterCriticalSection(&_mutex);
}
"If the critical section is successfully entered or the current thread already owns the critical section, the return value is nonzero.
If another thread already owns the critical section, the return value is zero."
Posix:
inline bool os::PlatformMutex::try_lock() {
int status = pthread_mutex_trylock(mutex());
assert_status(status == 0 || status == EBUSY, status, "mutex_trylock");
return status == 0;
}
"The pthread_mutex_trylock() function shall be equivalent to pthread_mutex_lock(), except that if the mutex object referenced by mutex is currently locked (by any thread, including the current thread), the call shall return immediately."
and:
"[EDEADLK]
A deadlock condition was detected or the current thread already owns the mutex."
This difference propagates up to the Mutex::try_lock implementation.
- blocks
-
JDK-8231627 ThreadsListHandleInErrorHandlingTest.java fails in printing all threads
- Resolved
- relates to
-
JDK-8210832 Remove sneaky locking in class Monitor
- Resolved
-
JDK-8255678 Add Mutex::try_lock version without rank checks
- Resolved