C++一个类模板里使用迭代器的问题
template<typenameHashedObj>classHashTable{public:explicitHashTable(intsize=101);boolr...
template <typename HashedObj>
class HashTable{
public:
explicit HashTable(int size=101);
bool remove(const HashedObj& x);
private:
vector<list<HashedObj> >theLists;
int currentSize;
typedef list<HashedObj>::iterator Litr;
Litr& find(const Litr& start,const Litr& end,const HashedObj& x) const{
for(Litr itr=start;itr!=end;itr++)
if(x==*itr)
return itr;
return end;
}
};
上面代码没给完整,只给了出问题的部分
大概意思就是一个分离链接法的散列表实现,然后remove函数里想用一个list<HashedObj>类型的迭代器来完成查询和删除工作,然后编译提示如下:
need 'typename' before 'std::list<HashedObj>::iterator' because 'std::list<HashedObj>' is a dependent scope
想问一下为什么不能这样使用不确定类型的迭代器,修改的话就只能把HashedObj替换成特定类型吗?
麻烦各位看下问题在哪里,谢谢了~ 展开
class HashTable{
public:
explicit HashTable(int size=101);
bool remove(const HashedObj& x);
private:
vector<list<HashedObj> >theLists;
int currentSize;
typedef list<HashedObj>::iterator Litr;
Litr& find(const Litr& start,const Litr& end,const HashedObj& x) const{
for(Litr itr=start;itr!=end;itr++)
if(x==*itr)
return itr;
return end;
}
};
上面代码没给完整,只给了出问题的部分
大概意思就是一个分离链接法的散列表实现,然后remove函数里想用一个list<HashedObj>类型的迭代器来完成查询和删除工作,然后编译提示如下:
need 'typename' before 'std::list<HashedObj>::iterator' because 'std::list<HashedObj>' is a dependent scope
想问一下为什么不能这样使用不确定类型的迭代器,修改的话就只能把HashedObj替换成特定类型吗?
麻烦各位看下问题在哪里,谢谢了~ 展开
2个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询