使用std :: apply迭代元组元素

时间:2017-04-21 11:10:43

标签: c++ lambda tuples c++17

我想实现一种将函数应用于给定元组的每个元素的方法,我想出了一个解决方案,在下面的例子中进行了演示。

int main()
{
    std::apply([](auto&&... xs)
               { 
                   [](...){}(([](auto&& x){ std::cout << x << "\n"; }(std::forward<decltype(xs)>(xs)), false)...); 
               }, std::make_tuple(1, 2.f, 3.0));
}

这似乎工作得很好,除了元组元素似乎以反转顺序处理,导致以下输出:

第3
2
1

谁能告诉我为什么?

1 个答案:

答案 0 :(得分:8)

未评估内部空lambda [](...){}的参数的计算顺序(即使在paper on evaluation order之后)。

只需在逗号运算符上使用折叠:

std::apply([](auto&&... xs) {
               ((std::cout << std::forward<decltype(xs)>(xs) << '\n'), ...); },
           std::make_tuple(1, 2.f, 3.0));

Demo。或直接在cout上二进制折叠。一旦我们引入了“packize”运算符,已经提出了一个提案(使用[:]),您也可以编写(std::cout << [:]tup << '\n'), ...