Undefined количество аргументов в С++

Могу ли я перегрузить мою функцию, чтобы сделать что-то с большим количеством аргументов, как в JavaScript. Например:

function f()
{
  alert(arguments[0]);
}

f(4); // will alert 4 

Могу ли я сделать то же самое в С++?

Ответ 1

Вы можете использовать переменные аргументы шаблона и кортежи:

#include <tuple>
#include <iostream>

template <class... Args>
void f(Args&&... args)
{
    auto arguments = std::make_tuple(std::forward<Args>(args)...);
    std::cout << std::get<0>(arguments);
}

void f() {} // for 0 arguments

int main()
{
    f(2, 4, 6, 8);
}

Live Demo

Для проверки границ попробуйте выполнить следующее:

#include <tuple>
#include <iostream>

template <class... T>
struct input
{
    std::tuple<T...> var;
    input(T&&... t) : var(std::forward<T>(t)...) {}

    template <std::size_t N, bool in_range = 0 <= N && N < std::tuple_size<decltype(var)>::value>
    auto get() -> typename std::tuple_element<in_range ? N : 0, std::tuple<T...>>::type
    {
        return std::get<in_range ? N : 0>(var);
    }
};

template <class... Args>
void f(Args&&... args)
{
    auto arguments = input<Args...>(std::forward<Args>(args)...);

    std::cout << arguments.template get<9>();
}

void f() {} // for 0 arguments

int main()
{
    f(2, 4, 6, 8);
}

Обновление. Если вам нужен первый аргумент, вам просто нужна функция, которая предоставляет этот первый аргумент, отделяя его от пакета параметров:

template<class Head, class... Tail>
void foo(Head&& head, Tail&&... tail);

Если это неудовлетворительно (т.е. вы хотите получить n-й аргумент), вы можете распаковать аргументы в std::tuple<> и извлечь элемент с помощью std::get<>:

template<class... Args>
void foo(Args&&... args)
{
    auto t = std::forward_as_tuple(std::forward<Args>(args)...);
    print(std::get<5>(t));
}