recursive_timed_mutex 类
表示定时互斥体类型。 此类型的对象用于在程序内通过使用时间限制阻止来强制实现互相排斥。 与 timed_mutex 类型的对象不同,为 recursive_timed_mutex
对象调用锁定方法的效果是有明确定义的。
语法
class recursive_timed_mutex;
成员
公共构造函数
名称 | 描述 |
---|---|
recursive_timed_mutex | 构造未锁定的 recursive_timed_mutex 对象。 |
~recursive_timed_mutex 析构函数 | 释放由 recursive_timed_mutex 对象使用的任何资源。 |
公共方法
名称 | 描述 |
---|---|
lock | 阻止调用线程,直到线程获取 mutex 的所有权。 |
try_lock | 在不阻止的情况下尝试获取 mutex 的所有权。 |
try_lock_for | 尝试获取在指定时间间隔内有效的 mutex 的所有权。 |
try_lock_until | 尝试获取在指定时间之前有效的 mutex 的所有权。 |
unlock | 释放 mutex 的所有权。 |
要求
标头:<mutex>
命名空间: std
lock
阻止调用线程,直到线程获取 mutex
的所有权。
void lock();
备注
如果调用线程已拥有 mutex
,则该方法将立即返回,同时上一锁定保持有效。
recursive_timed_mutex 构造函数
构造未锁定的 recursive_timed_mutex
对象。
recursive_timed_mutex();
~recursive_timed_mutex 析构函数
释放由 recursive_timed_mutex
对象使用的任何资源。
~recursive_timed_mutex();
备注
如果当析构函数运行时对象被锁定,则该行为不确定。
try_lock
在不阻止的情况下尝试获取 mutex
的所有权。
bool try_lock() noexcept;
返回值
如果此方法成功获取 mutex
的所有权,或如果调用线程已拥有 mutex
,则为 true
;否则为 false
。
备注
如果调用线程已拥有 mutex
,则该函数将立即返回 true
,并且上一锁定一直保持有效。
try_lock_for
在不阻止的情况下尝试获取 mutex
的所有权。
template <class Rep, class Period>
bool try_lock_for(const chrono::duration<Rep, Period>& Rel_time);
参数
Rel_time
一个 chrono::duration 对象,指定此方法尝试获取 mutex
所有权的最大时间量。
返回值
如果此方法成功获取 mutex
的所有权,或如果调用线程已拥有 mutex
,则为 true
;否则为 false
。
注解
如果调用线程已拥有 mutex
,则该方法将立即返回 true
,同时上一锁定保持有效。
try_lock_until
在不阻止的情况下尝试获取 mutex
的所有权。
template <class Clock, class Duration>
bool try_lock_for(const chrono::time_point<Clock, Duration>& Abs_time);
bool try_lock_until(const xtime* Abs_time);
参数
Abs_time
一个时间点,指定阈值,在此之后此方法不再尝试获取 mutex
所有权。
返回值
如果此方法成功获取 mutex
的所有权,或如果调用线程已拥有 mutex
,则为 true
;否则为 false
。
注解
如果调用线程已拥有 mutex
,则该方法将立即返回 true
,同时上一锁定保持有效。
解锁
释放 mutex
的所有权。
void unlock();
备注
仅当 mutex
的调用次数与在 recursive_timed_mutex
对象上成功调用 lock、try_lock、try_lock_fortry_lock_until 的次数一样多时,此方法才释放其所有权。
如果调用的线程不拥有 mutex
,则该行为不确定。