std::future作为函数C++的参数

std::future as a parameter to a function C++

本文关键字:C++ 参数 函数 future std      更新时间:2023-10-16

请考虑以下代码

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;
}