Код:
#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;
Что не так в функции шаблона?
Проблема заключается в том, что вы не сделали свой вариант аргумента 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;
}
работает по назначению.
Существует ошибка синтаксиса (а 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/...)
..
была опечатка, исправлено. Удаление std::endl
из вызова не помогает, я думаю, проблема в самом шаблоне.
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>&)}
.
в заявлении о распаковке. Измените это наargs...