正在接收容器作为模板参数
Receiving container as template argument
本文关键字:参数 更新时间:2023-10-16
我想在某个模板函数中迭代一个容器。如果容器是deque,但它存储的类型未知,那么我尝试了:
template <typename T>
void PrintDeque(deque<T> d)
{
deque<T>::iterator it; //error here
for(it=d.begin();it!=d.end();it++)
cout<<*it<<" ";
cout<<endl;
}
或者,如果我尝试未知容器:
template <typename T>
void PrintDeque(T d)
{
T::iterator it; //error here
for(it=d.begin();it!=d.end();it++)
cout<<*it<<" ";
cout<<endl;
}
两者都会产生编译错误。如何在template函数中创建迭代器,以便对容器进行迭代?
template <typename T>
void PrintDeque(T d)
{
typename T::iterator it; //error here
for(it=d.begin();it!=d.end();it++)
cout<<*it<<" ";
cout<<endl;
}
在它之前需要typename
,因为编译器不知道你在命名类型或静态变量。它被称为从属类型。
http://pages.cs.wisc.edu/~driscoll/typename.html
作为旁白和评论其他答案。有些编译器不需要,有些编译器需要。GCC是需要澄清的编译器之一。
#include <deque>
#include <iostream>
using namespace std;
template<typename range>
void PrintEverythingIn(range C)
{
for (auto e : C)
cout << e << ' ';
cout << endl;
}
deque<int> demo { 1,2,3,4,5,6,7,8,9,10,1,2,3,4,5,6,7,8,9,20 };
int main() { PrintEverythingIn(demo); }
您可以使用以下代码:
template <typename T>
void PrintDeque(deque<T> d)
{
deque<T>::iterator it;
for(it=d.begin();it!=d.end();it++)
cout<<*it<<" ";
cout<<endl;
}
这段代码在我的vs12窗口上运行良好。
注:
template <typename T>
void PrintDeque(deque<T> d)
{
deque<typename T>::iterator it; //error here
for(it=d.begin();it!=d.end();it++)
cout<<*it<<" ";
cout<<endl;
}
你发布的这段代码在我的电脑上也运行良好。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用