C++ 具名要求:共享定时互斥体 (SharedTimedMutex)
来自cppreference.com
共享定时互斥体 (SharedTimedMutex) 要求扩展定时互斥体 (TimedMutex) 要求以包含共享锁所有权模式。
要求
另外,对于支持定时共享操作的共享定时互斥 (共享定时互斥体 (SharedTimedMutex) ) 类型对象 m
:
- 表达式 m.try_lock_shared_for(duration) 拥有下列属性
- 表现为原子操作。
- 试图在
duration
所指定的时常内获得互斥的共享所有权。若duration
小于或等于duration.zero()
,则试图获得所有权而不阻塞(如同用try_lock()
)。否则,此函数将阻塞直至得到互斥,或直至经过duration
所指定的时长。它仅若成功才在duration
内返回,但允许获得互斥失败,即使在duration
期间的某点,互斥不为另一线程所占有。任何情况下,若得到互斥则返回 true ,否则返回 false 。 - 若
try_lock_shared_for(duration)
成功,则同一对象上先前的unlock()
操作同步于此操作(等价于释放获得内存顺序 (std::memory_order) )。 - 若调用方线程已以任何模式占有互斥,则行为未定义。
- 若抛出异常,则不获得共享锁。
- 表达式 m.try_lock_shared_until(time_point) 拥有下列属性
- 表现为原子操作。
- 试图在
time_point
前剩余的时间内获得互斥的共享所有权。若已经过time_point
,则试图获得所有权而不阻塞(如同用try_lock()
)。否则,此函数将阻塞直至得到互斥,或直至经过time_point
所制定的时间点。它仅若成功才在time_point
前返回,但允许获得互斥失败,即使在time_point
前的某点,互斥不为另一线程所占有。任何情况下,若得到互斥则返回 true ,否则返回 false 。 - 若
try_lock_shared_until(time_point)
成功,则同一对象上先前的unlock()
操作同步于此操作(等价于释放获得内存顺序 (std::memory_order) )。 - 若调用方线程已以任何模式占有互斥,则行为未定义。
- 若抛出异常,则不获得共享锁。
库类型
下列标准库类型满足共享定时互斥体 (SharedTimedMutex) :