在我的头文件中,我有
template <typename T>
class Vector {
public:
typedef T* iterator;
typedef const T* const_iterator;
Vector(const_iterator start, const_iterator end);
// other stuff ...
}
在.cpp文件中我有
template <typename T>
Vector< T >::Vector( const_iterator start, const_iterator end ) : theSize( 0 ), theCapacity( 1 )
{
array = new T[ theCapacity ];
typename Vector< T >::iterator itr = start; // this is line 29
for( iterator itr = start; itr != end; itr++ ){
push_back( *itr );
}
}
然而编译器告诉我
Vector.cpp:29: error: invalid conversion from ‘const int*’ to ‘int*’
如何在将参数保持为const_iterator的情况下解决此问题?
注意:如果它有助于我尝试在开始和结束之间使用另一个Vector中的元素构造Vector。
答案 0 :(得分:3)
我在这里没有看到在循环中不使用const_iterator
的原因。此外,您的push_back
函数不应接受迭代器,而应接受值。
因此,我会按如下方式重写相关部分:
typename Vector< T >::const_iterator itr = start;
for(const_iterator itr = start; itr != end; itr++ ){
push_back(*itr);
}
答案 1 :(得分:0)
您应该push_back(*itr)
代替push_back(itr)
,这将解决您的问题
答案 2 :(得分:0)
for循环只需要使用const_iterator。迭代器的常量仅适用于它的值,它仍然可以递增。你也可以使用你已经拥有的那个。
Vector(const_iterator pos, const_iterator end)
{
for( ; pos != end; pos++ ){
push_back( *pos );
}
}
答案 3 :(得分:0)
正如Andy所说,你需要一个const迭代器。如果您的编译器支持C ++ 11,则代码将变为:
template <typename T>
Vector< T >::Vector( const_iterator start, const_iterator end ) :
theSize( 0 ),
theCapacity( 1 )
{
array = new T[ theCapacity ];
for( auto itr = start; itr != end; itr++ ){
push_back( *itr );
}
}
我还要问:你确定要手动滚动自己的Vector吗?你有充分的理由不使用std :: vector吗?