Is it ok to destroy a std::promise before future.get() is called?(是否可以在调用future.get()之前销毁std::Promise?)
问题描述
我想知道是否可以调用promise.get_Future(),将那个未来移到其他地方(例如,移到一个向量中),甚至在调用future.get()之前就让承诺消亡。在下面的示例中,调用gateway->refreshWithCallback在线程中执行lambda,以便共享指针可以将Promise设置为释放,即使在第二个循环中还没有调用future.get(),这似乎是有效的,但我感到不安!
std::vector<std::future<bool>> futures;
for(GuiGateway *gateway : gateways){
std::shared_ptr<std::promise<bool>> shared_promise_ptr(new std::promise<bool>());
futures.push_back(shared_promise_ptr.get()->get_future());
gateway->refreshWithCallback([shared_promise_ptr](bool success){
shared_promise_ptr.get()->set_value(success);
});
}
qDebug() << "waiting for futures";
for(std::future<bool> &future : futures){
if(future.get() == false){
qDebug() << "error retrieving all gateway data, aborting auto config";
return;
}
}
推荐答案
如果您在销毁std::promise之前向提供了一个值,关联的std::future将能够很好地检索它。它不依赖于仍然存在的std::promise。如果在销毁std::promise之前未能为std::promise提供值,则尝试从std::future获取结果将引发std::future_error,但它也定义良好。
这篇关于是否可以在调用future.get()之前销毁std::Promise?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:是否可以在调用future.get()之前销毁std::Promise?
基础教程推荐
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- CString 到 char* 2021-01-01
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 初始化列表*参数*评估顺序 2021-01-01
