std::coroutine_handle<Promise>::operator(), std::coroutine_handle<Promise>::resume

 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等字符串转换
(C++17)
(C++17)
 
协程支持
协程特征
协程柄
无操作协程
平凡可等待体
 
std::coroutine_handle
成员函数
观察器
控制
coroutine_handle::operator()coroutine_handle::resume
(C++20)(C++20)
承诺访问
导出/导入
非成员函数
(C++20)(C++20)
辅助类
 
特化 std::coroutine_handle<> 的成员
void operator()() const;
void resume() const;
(1) (C++20 起)
特化 std::coroutine_handle<std::noop_coroutine_promise> 的成员
constexpr void operator()() const noexcept;
constexpr void resume() const noexcept;
(2) (C++20 起)
1) 恢复 *this 所指代的协程的执行,或若该协程为无操作协程则不做任何事。

若需要恢复且 *this 不指代协程或该协程在最终暂停点暂停,则行为未定义。同时恢复协程可能导致数据竞争。

主模板使用这些函数。
2) 不做任何事。

在不同于协程暂停所在的执行代理上恢复协程拥有实现定义行为,除非每个执行代理都是由 std::threadstd::jthread 表示的线程,或执行 main 的线程。

参数

(无)

返回值

(无)

注解

在不同执行代理上恢复的协程应该处处避免依赖一致的线程同一性,例如跨过暂停点保有互斥体对象。

当前标准草案要求在从 std::noop_coroutine_handle 转换得到的 std::coroutine_handle<> 上调用 operator()resume 亦为无操作,这是不可实现的,因为 std::noop_coroutine_handle 可以指代非无操作的协程或不指代协程。此为 LWG 问题 3460

示例

参阅

(C++20)
销毁协程
(公开成员函数)