使用VS2017和代码: template typename Tvoid showset(vectorT v){ for (vectorT::iterator it = v.begin(); it != v.end(); it++) { cout *it; } cout endl;} 错误是: error C2760: syntax error: unexpected token , expected ‘;’ 问题是如
template <typename T>
void showset(vector<T> v)
{
for (vector<T>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it;
}
cout << endl;
}
错误是:
error C2760: syntax error: unexpected token , expected ‘;’
问题是如何使用模板的迭代器
首先请注意,如果在此处引用类似于矢量< T> :: iterator的 template argument dependent name,则需要先输入typename.此外,取决于T是什么,只有当std :: cout的运算符<<正在接受这个T.例如,编译就好了:#include <iostream>
#include <vector>
template <typename T>
void showset(std::vector<T> v)
{
for (typename std::vector<T>::iterator it = v.begin(); it != v.end(); it++)
{
std::cout << *it;
}
std::cout << std::endl;
}
struct foo
{
};
int main()
{
showset(std::vector<int>{1,2,3});
//showset(std::vector<foo>{}); // Error: `cout` doesn't take `foo`s.
return 0;
}
使用C11的auto增强语法,showset()可以像这样编写,然后typename没有用处:)
template <typename T>
void showset(std::vector<T> v)
{
for (auto it = v.begin(); it != v.end(); it++)
{
std::cout << *it;
}
std::cout << std::endl;
}
此外,从C 11开始,您可以使用range-based for loop实现与原始代码段相同的内容:
template <typename T>
void showset(std::vector<T> v)
{
for (auto& ref : v)
{
std::cout << ref;
}
std::cout << std::endl;
}
与lase版本一样,因为你没有在这里引用迭代器类型,所以没有什么可以放置typename.
请注意,在两个版本中,您都是按值获取参数v.因此,您正在为每个函数调用复制整个向量.由于代码是在问题中给出的,所以似乎没有理由这样做,所以你应该通过引用传递它,并使它成为一个const,因为你没有在showset()内的任何地方修改v:
void showset(const std::vector<T>& v);
然后在非基于范围的for循环版本中,不要忘记相应地更改循环语句:
for (typename std::vector<T>::const_iterator it = v.begin(); it != v.end(); it++)
