Как написать базовый класс и несколько производных классов итератора?Итератор Наследование и наследование * this
Должен ли итератор возвращаться сам (* это)?
До сих пор я использовал typename X
и static_cast<X&>(*this)
, чтобы производный класс мог наследовать функцию, возвращающуюся из базового класса.
This
выглядит уродливым. Есть ли способ лучше?
упрощенный код:
#include <iterator>
#include <iostream>
template <typename T, typename X>
class BaseIterator : public std::iterator<std::input_iterator_tag, T> {
//Not intended to be used directly.
private:
T* p;
protected:
virtual void increment(void)=0;
virtual T* stride_index(int index)=0;
public:
virtual ~BaseIterator(){} //virtual destructor.
X operator++(int) { //takes a dummy int argument
X tmp(static_cast<X&>(*this));
increment();
return tmp;
}
bool operator==(const X & rhs) { return p==rhs.p; }
} ;
template <typename T>
class ContiguousIterator : public BaseIterator<T, ContiguousIterator<T> > {
private:
T* p;
protected:
inline void increment(void) {++p;}
inline T* stride_index(int index){return p + index;}
public:
virtual ~ContiguousIterator(){} //destructor.
ContiguousIterator(T* x) :p(x) {}
ContiguousIterator(const ContiguousIterator<T> & mit) : p(mit.p) {}
} ;
int main(void){
int i[]={0,1,2,3,4,5};
ContiguousIterator<int> itbegin(i);
ContiguousIterator<int> it(i);
it++;
std::cout << "result: " << (it == itbegin) << std::endl;
}
В качестве альтернативы можно забыть об использовании наследования писать меньше кода. Просто скопируйте и вставьте функцию, возвращающую *this
в производные классы.
Эта альтернатива кажется более приемлемым для меня ...
Кроме того, 'ContiguousIterator' имеет два несвязанных общественные' T * p' members. Это просто хаос. –
Я не знал crtp. Помогло бы crtp в этом случае? – rxu
простой исправление: изменение T * p частное. Невозможно изменить его на защищенный. некоторые как. Раньше я пытался. – rxu