std::shared_mutex::unlock_shared

From cppreference.com
< cpp‎ | thread‎ | shared mutex
 
 
Concurrency support library
Threads
(C++11)
(C++20)
(C++20)
this_thread namespace
(C++11)
(C++11)
(C++11)
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11)(deprecated in C++20)
(C++11)(deprecated in C++20)
Free functions for atomic operations
Free functions for atomic flags
Memory ordering
Mutual exclusion
(C++11)
Generic lock management
(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Condition variables
(C++11)
Semaphores
Latches and barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
(C++11)
 
 
void unlock_shared();
(since C++17)

Releases the mutex from shared ownership by the calling thread.

The mutex must be locked by the current thread of execution in shared mode, otherwise, the behavior is undefined.

This operation synchronizes-with (as defined in std::memory_order) any subsequent lock() operation that obtains ownership of the same mutex.

Parameters

(none)

Return value

(none)

Exceptions

Throws nothing.

Notes

unlock_shared() is usually not called directly: std::shared_lock is used to manage shared locking.

Example

See also

locks the mutex for shared ownership, blocks if the mutex is not available
(public member function)
unlocks the mutex
(public member function)