命名空间
变体
操作

std::counting_semaphore<LeastMaxValue>::try_acquire_for

来自 cppreference.cn
 
 
并发支持库
线程
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协同取消
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
门闩和屏障
(C++20)
(C++20)
期值
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
危险指针
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存排序
(C++11)(C++26 中已弃用)
原子操作的自由函数
原子标志的自由函数
 
 
template< class Rep, class Period >
bool try_acquire_for( const std::chrono::duration<Rep, Period>& rel_time );
(C++20 起)

尝试原子地减少内部计数器 1,如果它大于 0 的话;否则阻塞直到它大于 0 且能成功减少内部计数器,或者超过 rel_time 时长。

目录

[编辑] 前置条件

(无)

[编辑] 参数

rel_time - 函数必须等待到失败的最小时长

[编辑] 返回值

如果它成功地将内部计数器减 1 则返回 true,否则返回 false

[编辑] 异常

可能抛出 std::system_error 或与超时相关的异常。

[编辑] 注意

实践中,函数可能花费比 rel_time 更长的时间才失败。

[编辑] 参阅

增加内部计数器并解除阻塞获取器
(公开成员函数) [编辑]
递减内部计数器或阻塞直到可以递减
(公开成员函数) [编辑]
尝试递减内部计数器而不阻塞
(公开成员函数) [编辑]
尝试递减内部计数器,阻塞直到某一时间点
(公开成员函数) [编辑]