Параметры функции шаблона Variadic и вычет ссылочного типа - PullRequest
0 голосов
/ 09 сентября 2018

Я упускаю кое-что очень фундаментальное в выводе типа здесь:

Я пытаюсь написать функцию-обертку, которая вызывает функцию записи с nullptr для получения требуемой длины, затем изменяет размер буфера, затем снова вызывает функцию, теперь с измененным размером буфера, чтобы получить окончательный вывод. Существует большое количество этих функций записи, и я хочу обобщить шаблон call / resize / call в функцию шаблона variadic.

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

static void val_arg(int)            { }
static void ref_arg(const int&)     { }

template <typename... Args>
static void helper(void (*fun)(Args...), Args... args)
{
    (*fun)(args...);
}

void proxy(const int& arg)
{
    helper(&val_arg, arg);  // Fine
    helper(&ref_arg, arg);  // 'void helper(void (__cdecl *)(Args...),Args...)': template parameter 'Args' is ambiguous
                            // note: could be 'const int&'
                            // note: or       'int'
}

void test()
{
    proxy(1);               // Force 1 to be const int&
}

Что я могу сделать, чтобы он прозрачно принимал оба случая? Почему он не подтверждает, что переданная функция принимает const ref, а аргумент прокси-сервера также является const ref?

1 Ответ

0 голосов
/ 09 сентября 2018

Args... не выведет тип ссылки.

template <typename Fun, typename... Args>
static void helper(Fun fun, Args&&... args)
{
    fun(std::forward<Args>(args)...);
}
...