我想实现一种将函数应用于给定元组的每个元素的方法,我想出了一个解决方案,在下面的例子中进行了演示。
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
谁能告诉我为什么?
答案 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'), ...
。