1

考虑以下使用折叠表达式打印参数的函数。

template <typename... T>
void print(T &&... t)
{
    (std::cout << ... << t) << '\n';
}

考虑调用它的第二个函数:

template <typename T, T... vals>
void call_print(std::integer_sequence<T, vals...> &&)
{
    print(vals...); //ok: prints 01234
}
call_print(std::make_index_sequence<5>{});

在我的用例中,我需要这样调用print(使用折叠表达式)

template <typename T, T... vals>
void call_print2(std::integer_sequence<T, vals...> &&)
{
    print((vals, ...)); //not OK: only prints 4
}
call_print2(std::make_index_sequence<5>{});

在这种情况下,调用看起来像这样

print(0,(1,(2,(3,4))));

但是该函数似乎只捕获了最后一个参数,就好像我这样称呼它:

print(4);

任何帮助,将不胜感激

编辑:我实际上想要完成的事情

template<typename T, T ... ints>
auto make_seq(std::integer_sequence<T, ints...>&&)
{
   auto lambda = []<T val>()->T{/*implementation doesn't matter*/};
   return std::integer_sequence<T, (lambda.template operator()<ints>(), ...)>{}; //<- right here
}
4

1 回答 1

3

print((vals, ...))扩展到print((0, 1, 2, 3, 4)). (0, 1, 2, 3, 4)是使用逗号运算符的表达式。逗号运算符计算其两个操作数并丢弃表达式左侧的结果。这意味着表达式的(0, 1, 2, 3, 4)计算结果为 value 4。因此print((vals, ...))是 一样print((0, 1, 2, 3, 4))是 一样print(4)

通常,折叠表达式是表达式,因此计算为单个值。您需要改用普通的参数包扩展。例如:

template<typename T, T... ints>
auto make_seq(std::integer_sequence<T, ints...>&&)
{
   auto lambda = []<T val>()->T{/*implementation doesn't matter*/};
   return std::integer_sequence<T, lambda.template operator()<ints>()...>{};
}

现场演示

于 2020-06-09T22:11:18.807 回答