如何在C ++中复制const_iterator

时间:2013-02-14 23:00:29

标签: c++ iterator

在我的头文件中,我有

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。

4 个答案:

答案 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吗?