Вопрос о векторном итераторе в функциях шаблона
Я пытаюсь изучить библиотеку STL, и у меня возникла странная проблема. Этот код отлично компилируется:
void Show(vector<int> myvec)
{
vector<int>::iterator it;
cout << "Vector contains:";
for( it = myvec.begin(); it < myvec.end(); it++)
{
cout << " " << *it;
}
cout << endl;
}
в то время как во время компиляции мне присваивается сообщение об ошибке:
template <class T>
void Show2(vector<T> myvec)
{
vector<T>::iterator it;
cout << "Vector contains:";
for( it = myvec.begin(); it < myvec.end(); it++)
{
cout << " " << *it;
}
cout << endl;
}
Ошибка:
$ g++ hello.cpp
hello.cpp: In function ‘void Show2(std::vector<T, std::allocator<_Tp1> >)’:
hello.cpp:19: error: expected ‘;’ before ‘it’
hello.cpp:21: error: ‘it’ was not declared in this scope
Кажется, очень простая ошибка, но я не мог ее найти.
Ответы
Ответ 1
Вам нужно сказать typename vector<T>::iterator it
.
С другой стороны, вы передаете vector
по значению. Это означает, что весь vector
будет скопирован в вызове функции. void Show(vector<T> const &myvec)
и использование const_iterator
будет более разумным.
Ответ 2
Вам нужно следующее:
typename vector<T>::iterator it;
Это говорит компилятору, что vector<T>::iterator
следует рассматривать как тип, чего он не может предположить, поскольку iterator
зависит от того, что T
.
Ответ 3
У некоторых компиляторов есть проблемы с обнаружением имени участника и имени типа, когда внутри шаблонов. Попробуйте написать что-то вроде этого в первой строке вашего тела функции шаблона.
typename vector<T>::iterator it;
Ответ 4
Возможно, он работает с помощью typename vector<T>::iterator it;
Ваш компилятор не может знать, что есть итератор внутреннего класса.
Ответ 5
В первом случае параметр, хотя он использует шаблон, не является шаблоном, это полностью определенный класс (vector<int>
)
В последнем случае параметр является шаблоном для типа T и, следовательно, требует typename