如何通过参数包传递引用?

p12*_*p12 8 c++ reference variadic-templates c++11

我有以下代码:

#include <cstdio>

template<class Fun, class... Args>
void foo(Fun f, Args... args)
{
    f(args...);
}

int main()
{
    int a = 2;
    int b = 1000;

    foo([](int &b, int a){ b = a; }, b, a);
    std::printf("%d\n", b);
}
Run Code Online (Sandbox Code Playgroud)

目前它打印1000,即b在某处丢失的新价值.我想这是因为foo通过值传递参数包中的参数.我该如何解决这个问题?

BЈо*_*вић 11

通过使用参考:

template<class Fun, class... Args>
void foo(Fun f, Args&&... args)
{
    f( std::forward<Args>(args)... );
}
Run Code Online (Sandbox Code Playgroud)

  • 如果`a`是一个右值,这将失败,即使这应该在语义上是允许的.我认为`&&`会更好. (3认同)
  • 你应该转发:`f(std :: forward <Args>(args)...);` (2认同)

Nim*_*Nim 7

像这样:

#include <iostream>
#include <functional>

template<class Fun, class... Args>
void foo(Fun f, Args... args)
{
    f(args...);
}

int main()
{
    int a = 2;
    int b = 1000;

    foo([](int &b, int a){ b = a; }, std::ref(b), a);
    std::cout << b << std::endl;
}
Run Code Online (Sandbox Code Playgroud)