std::counting_semaphore<LeastMaxValue>::try_acquire_for
来自 cppreference.com
< cpp | thread | counting semaphore
template< class Rep, class Period > bool try_acquire_for( const std::chrono::duration<Rep, Period>& rel_time ); |
(自 C++20 起) | |
如果内部计数器大于 1,则尝试原子地将内部计数器减少 1;否则会阻塞,直到它大于 0 并且可以成功减少内部计数器,或者 rel_time 时长已超过。
内容 |
[编辑] 前提条件
(无)
[编辑] 参数
rel_time | - | 函数必须等待才能失败的最小时长 |
[编辑] 返回值
如果它减少了内部计数器,则为 true,否则为 false.
[编辑] 异常
可能会抛出 std::system_error 或与超时相关的异常。
[编辑] 注意
实际上,该函数可能需要比 rel_time 更长的时间才能失败。
[编辑] 另请参见
增加内部计数器并解除获取者的阻塞 (公共成员函数) | |
减少内部计数器或阻塞直到可以减少 (公共成员函数) | |
尝试在不阻塞的情况下减少内部计数器 (公共成员函数) | |
尝试减少内部计数器,阻塞直到某个时间点 (公共成员函数) |