Как разделить кортеж в С++

У меня вопрос о разделении кортежа, как сказано в названии.

На самом деле, я могу сделать это с помощью std::index_sequence, но код выглядит уродливым.

Есть ли элегантный способ сделать это?

Вот какой код, чтобы показать, что я имею в виду.

#include<tuple>
using namespace std;

template<typename THead, typename ...TTails>
void foo(tuple<THead, TTails...> tpl)
{
    tuple<THead> tpl_h { get<0>(tpl) };
    tuple<TTails...> tpl_t { /* an elegent way? */ }
    do_sth(tpl_h, tpl_t);
}

int main()
{
    foo(make_tuple(1, 2.0f, 'c'));
    return 0;
}

Ответы

Ответ 1

Если у вас есть компилятор с поддержкой С++ 17, вы можете использовать apply:

auto [tpl_h, tpl_t] = apply([](auto h, auto... t) {
    return pair{tuple{h}, tuple{t...}};
}, tpl);
do_sth(tpl_h, tpl_t);

Пример.

Поскольку вы используете VS2015.2, который поддерживает С++ 14 и более поздний черновик n4567, вы справедливо ограничено в доступной библиотечной поддержке. Однако вы можете использовать piecewise_construct:

struct unpacker {
    tuple<THead> tpl_h;
    tuple<TTails...> tpl_t;
    unpacker(THead h, TTails... t) : tpl_h{h}, tpl_t{t...} {}
};
auto unpacked = pair<unpacker, int>{piecewise_construct, tpl, tie()}.first;
do_sth(unpacked.tpl_h, unpacked.tpl_t);

Пример.