std::packaged_task<R(Args...)>::operator()
来自cppreference.com
< cpp | thread | packaged task
并发支持库
|
|
std::packaged_task
成员函数 | ||||
获取结果 | ||||
执行 | ||||
packaged_task::operator()
|
||||
非成员函数 | ||||
辅助类 | ||||
(C++17
前)
|
||||
推导指引(C++17) |
void
operator()(
ArgTypes... args
);
|
(C++11 起) | |
如同以 INVOKE<R>(f, args...) 调用存储的任务 f。任务返回值或任何抛出的异常被存储于共享状态。令共享状态就绪,并解除阻塞任何等待此操作的线程。
参数
args | - | 调用时传递给存储任务的参数 |
返回值
(无)
异常
在以下情况抛出 std::future_error:
- 存储的任务已经被调用过。此时设置错误类别为 promise_already_satisfied 。
- *this 没有共享状态。此时设置错误类别为 no_state。
示例
本节未完成 原因:暂无示例 |
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 2142 | C++11 | 对 operator() 的成功调用会与对
*this
共享共享状态的 std::future 或 std::shared_future 的任意成员函数的调用同步 |
不会在共享状态已提供的 内容外作任何同步保证 |
参阅
执行函数,并确保结果仅在一旦当前线程退出时就绪 (公开成员函数) |