std::shared_future<T>::valid
来自 cppreference.cn
< cpp | thread | shared future
bool valid() const noexcept; |
(自 C++11 起) | |
检查 future 是否引用共享状态。
仅对于非默认构造或从其移动的 future 才是这种情况。与 std::future 不同,调用 get()
时,std::shared_future
的共享状态不会失效。
如果对不引用共享状态的 shared_future
调用除了析构函数、复制赋值运算符、移动赋值运算符或 valid
之外的任何成员函数,则行为未定义(但鼓励实现抛出 std::future_error,表明在这种情况下 no_state
)。从 valid()
为 false 的 shared_future 对象移动或复制是有效的。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
如果 *this 引用共享状态,则为 true,否则为 false。
[编辑] 示例
运行此代码
#include <future> #include <iostream> int main() { std::promise<void> p; std::shared_future<void> f = p.get_future(); std::cout << std::boolalpha; std::cout << f.valid() << '\n'; p.set_value(); std::cout << f.valid() << '\n'; f.get(); std::cout << f.valid() << '\n'; }
输出
true true true
[编辑] 参见
等待结果变为可用 (公共成员函数) |