Ich schreibe eine eigene Container-Klasse und habe in ein Problem gerannt, das ich nicht verstehen kann. Hier ist das Beispiel mit dem bloßen Knochen, das das Problem zeigt.C++ - Iterator und const_iterator Problem für eigene Container-Klasse
Es besteht aus einer Containerklasse und zwei Testklassen: eine Testklasse mit einem std: vector, die gut kompiliert und die zweite Testklasse, die versucht, meine eigene Containerklasse auf genau die gleiche Weise zu verwenden, aber kläglich kompiliert.
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std;
template <typename T>
class MyContainer
{
public:
class iterator
{
public:
typedef iterator self_type;
inline iterator() { }
};
class const_iterator
{
public:
typedef const_iterator self_type;
inline const_iterator() { }
};
iterator begin() {
return iterator();
}
const_iterator begin() const {
return const_iterator();
}
};
// This one compiles ok, using std::vector
class TestClassVector
{
public:
void test() {
vector<int>::const_iterator I=myc.begin();
}
private:
vector<int> myc;
};
// this one fails to compile. Why?
class TestClassMyContainer
{
public:
void test(){
MyContainer<int>::const_iterator I=myc.begin();
}
private:
MyContainer<int> myc;
};
int main(int argc, char ** argv)
{
return 0;
}
gcc sagt mir:
test2.C: In member function ‘void TestClassMyContainer::test()’:
test2.C:51: error: conversion from ‘MyContainer::iterator’ to non-scalar type ‘MyContainer::const_iterator’ requested
Ich bin nicht sicher, wo und warum der Compiler will einen Iterator auf eine const_iterator für meine eigene Klasse konvertieren, aber nicht für die STL-Vektor-Klasse. Was mache ich falsch?
Vielen Dank. Jetzt muss ich nur sehen, ob ich const_iterator als Freund von Iterator deklariere ... oder Accessorfunktionen in private Iterator-Member schreiben, aber das sollte machbar sein. – BaCh