Wie schreibe ich eine Basisklasse und mehrere abgeleitete Iteratorklassen?Iterator Vererbung und Vererbung * Dies
Muss der Iterator sich selbst zurückgeben (* dies)?
Bisher verwende ich typename X
und static_cast<X&>(*this)
, damit die abgeleitete Klasse eine Funktion erben kann, die sich von der Basisklasse zurückgibt.
This
sieht hässlich aus. Gibt es einen besseren Weg?
Simplified Code:
#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;
}
Die Alternative ist, über die Verwendung von Vererbung zu vergessen, weniger Code zu schreiben. Kopieren Sie einfach die Funktion, die *this
zurückgibt, und fügen Sie sie in die abgeleiteten Klassen ein.
Diese Alternative zu mir zunehmend akzeptabel scheint ...
auch 'ContiguousIterator' hat zwei unabhängige öffentliche' T * p' Mitglieder Chaos. –
Ich wusste nicht crtp. Würde Crtp in diesem Fall helfen? – rxu
einfache Lösung: Ändern Sie T * P zu privat. Kann nicht in "geschützt" geändert werden. irgendwie. Ich habe es schon mal versucht. – rxu