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 并能成功地将内部计数器减 1,或者 abs_time 时间点已经过去。
如果 std::chrono::is_clock_v<Clock> 为 false,则程序是非良构的。
目录 |
[编辑] 前置条件
Clock
满足 Clock 要求。
[编辑] 参数
abs_time | - | 函数必须等待的最早时间点,超过此时间点将导致失败。 |
[编辑] 返回值
如果它成功地将内部计数器减 1 则返回 true,否则返回 false。
[编辑] 异常
可能会抛出 std::system_error 或与超时相关的异常。
[编辑] 注释
实际上,函数可能需要比 abs_time 更长的时间才会失败。
[编辑] 参阅
增加内部计数器并解除阻塞获取器 (公共成员函数) | |
递减内部计数器或阻塞直到可以递减 (公共成员函数) | |
尝试递减内部计数器而不阻塞 (公共成员函数) | |
尝试递减内部计数器,阻塞一段持续时间 (公共成员函数) |