std::counting_semaphore<LeastMaxValue>::try_acquire_until
来自 cppreference.cn
< cpp | thread | counting semaphore
template< class Clock, class Duration > bool try_acquire_until( const std::chrono::time_point<Clock, Duration>& abs_time ); |
(C++20 起) | |
尝试原子地将内部计数器减 1,如果它大于 0;否则阻塞,直到它大于 0 并且可以成功地减少内部计数器,或者直到 abs_time 时间点已过。
如果 std::chrono::is_clock_v<Clock> 为 false,则程序是病式的。
内容 |
[edit] 先决条件
Clock
满足 Clock 的要求。
[edit] 参数
abs_time | - | 函数为了失败而必须等待的最早时间 |
[edit] 返回值
true 如果它减少了内部计数器,否则为 false。
[edit] 异常
可能抛出 std::system_error 或与超时相关的异常。
[edit] 注解
在实践中,该函数可能花费比 abs_time 更长的时间才能失败。
[edit] 参见
增加内部计数器并解除阻塞获取者 (公共成员函数) | |
减少内部计数器或阻塞直到可以减少 (公共成员函数) | |
尝试减少内部计数器而不阻塞 (公共成员函数) | |
尝试减少内部计数器,阻塞最多持续一段时间 (公共成员函数) |