Visual Studio 2015 Update 3中的co-await是否与std::experial::optio
Does co_await in Visual Studio 2015 Update 3 works with std::experimental::optional
互联网上有一些链接[1,2]建议co_await应该与std::experimental::optional
一起使用,VS 2015 Update 2应该支持这一点。由于VS即使在更新3中也没有可选的,我使用了github中的VS,但这样的代码无法编译:
optional<string> get_hope() {
if ((rand() % 4) == 0)
return nullopt;
return "yolo";
}
optional<string> bla() {
string s = co_await get_hope();
}
错误为:
错误(活动(此co-await表达式需要合适的"await_ready"函数,未找到
所以我的问题是我做错了什么,是库缺少了对wait的支持,还是编译器缺少了对co_await
这方面的支持。
互联网上有一些链接[1,2]建议co-await应该与std::experimental::optional 一起使用
您对这些链接的解释不正确。尽管无可否认,这一个本质上是设计的,以制造这种误解。
P0057"协程"本质上是函数挂起执行并在以后某个时间从挂起点继续执行的一种方式。造成这种情况的机制涉及函数的返回类型/签名与co_await
所依赖的表达式类型之间的一系列复杂交互。
人们发现了一种ab使用co_await
执行有效等价条件返回的方法。您可以将co_await
应用于optional
时,检查optional
的状态,如果它为空,则简单地退出函数。实际上,co_await
会说挂起函数(从而将控制权返回给调用者(,但从未计划其恢复。这创建了返回的效果(包括清理协程(,而不实际写入if(opt.empty()) return; else ...
。这也允许co_await
从optional
解包,如果值存储在其中
然而,这并不是因为optional
的存在而神奇地发生的。您必须构建特殊的co_await
机制,它既可以使用optional
作为co_await
表达式类型,也可以使用函数的返回值类型。
co_await
的VS2015实现为co_await
在std::future
上的实现提供了这种机制。但它不支持optional
或其他随机类型。你必须自己建造它,你引用的帖子都没有指出这一点。
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 使用std::函数映射对象方法
- Visual Studio 2015 Update 3中的co-await是否与std::experial::optio