std::future作为函数C++的参数
std::future as a parameter to a function C++
请考虑以下代码
void printPromised(std::future<int> f)
{
std::cout << f.get() << std::endl;
}
int main()
{
printPromised(std::async(std::launch::async, [](){ return 8; })); // This works
auto f = std::async(std::launch::async, [](){ return 8; });
printPromised(f); // This won't work
}
它说"这是一个已删除的功能"。为什么?此外,我需要将std::async
生成的相同承诺结果传递给多个用户。这意味着当有人调用 get() 函数时,我需要传递相同的结果(如果已经生成,我不需要使用 std::async
重新生成结果),并且我需要std::future::get
具有的阻止机制。
未来只能有一个。您不能拥有同一未来的多个副本。所以你需要将未来的所有权转移到函数:
printPromised(std::move(f));
// ^^^^^^^^^^^^
如果你确实需要对未来的共享访问,你可以通过调用 share()
成员函数来构造一个来自普通未来的shared_future
;其行为类似于共享指针:
auto sf = std::async(std::launch::async, [](){ return 8; }).share();
现在可以复制sf
,并且所有副本都等待相同的结果,即所有副本上的wait()
调用可能会阻塞并与结果的就绪同步。
这是我在这次讨论后提出的。
#include <future>
typedef std::shared_future<int> SharedFutureInt;
struct Object
{
SharedFutureInt m_promised;
bool isAssigned;
Object() : isAssigned(false)
{
}
SharedFutureInt getObjects()
{
if (isAssigned)
{
return m_promised;
}
m_promised = std::async(std::launch::async, [](){ return 8; });
isAssigned = true;
return m_promised;
}
};
int main()
{
Object obj;
int a = obj.getObjects().get();
int b = obj.getObjects().get();
int c = obj.getObjects().get();
return 0;
}
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用