Шаблон Variadic не скомпилирован

0

Код:

#include <iostream>

template<typename T>    
void out()                   // line 4
{
}

template<typename T, typename... Args>
void out(T value, Args... args)        // line 9
{
    std::cout << value;
    out(args...);    // line 12
}

int main()
{
    out("12345", std::endl);    // line 17
    return 0;
}

Ошибки сборки:

g++ -O0 -g3 -Wall -c -fmessage-length=0 -std=c++11 -pthread -MMD -MP -MF"main.d" -MT"main.d" -o "main.o" "../main.cpp"
../main.cpp: In function ‘int main():
../main.cpp:17:24: error: no matching function for call to ‘out(const char [6], <unresolved overloaded function type>)
../main.cpp:17:24: note: candidates are:
../main.cpp:4:6: note: template<class T> void out()
../main.cpp:4:6: note:   template argument deduction/substitution failed:
../main.cpp:17:24: note:   candidate expects 0 arguments, 2 provided
../main.cpp:9:6: note: void out(T, Args ...) [with T = const char*; Args = {}]
../main.cpp:9:6: note:   candidate expects 1 argument, 2 provided

Я хочу, чтобы эта программа давала тот же результат, что и std::cout << "12345" << std::endl; Что не так в функции шаблона?

  • 0
    Вы пропускаете . в заявлении о распаковке. Измените это на args...
  • 0
    Редактируя вопрос, есть еще сообщения с ...
Показать ещё 1 комментарий
Теги:
c++11
variadic-templates

2 ответа

6
Лучший ответ

Проблема заключается в том, что вы не сделали свой вариант аргумента out шаблона, и его нельзя вызвать без явной подачи аргументов шаблона. таким образом

void out() {}

template<typename T, typename... Args>
void out(T value, Args... args) {
    std::cout << value;
    out(args...);
}

int main() {
    out(1, 2.0, "3");
    return 0;
}

работает по назначению.

  • 0
    Слова, которые вы искали, являются «выводом типа аргумента».
3

Существует ошибка синтаксиса (а missning .), Что делает компилятор сходит с ума.

После этого у вас также может возникнуть проблема с вызовом out("12345", std::endl), будучи std::endl переопределенной функцией, которую не может выбрать компилятор (просто static_cast<std::ostream&(*)(std::ostream&)>(std::endl) ее как static_cast<std::ostream&(*)(std::ostream&)>(std::endl))

Кроме того, рекурсия в out не заканчивается out() вызова, но нет с 0 параметров (смотрите также ЮРИЙ ответ:. qaru.site/questions/7811403/...)

  • 0
    Благодарю. .. была опечатка, исправлено. Удаление std::endl из вызова не помогает, я думаю, проблема в самом шаблоне.
  • 0
    После удаления первой строки template это выглядит лучше. Вы правы, std::endl не скомпилирован. Но ваше приведение не работает: invalid static_cast from type '<unresolved overloaded function type>' to type 'std::ostream&(std::ostream&) {aka std::basic_ostream<char>&(std::basic_ostream<char>&)}
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню