Обернуть дескриптор итерации для использования в циклах for на основе диапазона

Я использую API, который поставляется с функциональностью итерации, используя void* справиться.

void* handle = BrowseInit();
while (BrowseGetNext(handle))
{
// ...
int x = BrowseGetData(handle);
}
BrowseFree(handle);

Как бы я обернул это в итератор C ++ 11 для использования в циклах for на основе диапазона? Так как значение handle на самом деле не меняется, мне нужно немного обмануть operator != (),

class Iterator
{
public:

friend class it;
class it
{
public:

it(Iterator* data) : _data(data) { }
bool operator != (const it& other) const
{
// what should I put in here?
}
const it& operator ++ ()
{
BrowseGetNext(_data->_handle);
}
int operator * () const
{
return BrowseGetData(_data->_handle);
}

private:
Iterator* _data;
};

Iterator() : _handle(BrowseInit()) { }
~Iterator()
{
BrowseFree(_handle);
}

it begin() const
{
return it(this);
}
it end() const
{
return it(nullptr);
}

private:

void* _handle;
};

3

Решение

Это должно работать.

class Iterator
{
public:

friend class it;
class it
{
public:

// Constructor for begin().
it(Iterator* data) : _data(data), index_(0) { }

// Constructor for end().
it(Iterator* data, int) : _data(data), index_(-1) { }

bool operator != (const it& other) const
{
return !(*this == other);
}
bool operator == (const it& other) const
{
return ( this->_data == other._data && this->_index == rhs._index );
}

const it& operator ++ ()
{
// Increment the index if there's more data.
// Otherwise, set it to -1.
if ( BrowseGetNext(_data->_handle) )
{
++index_;
}
else
{
index_ = -1;
}
}

int operator * () const
{
return BrowseGetData(_data->_handle);
}

private:
Iterator* _data;
int _index;
};

Iterator() : _handle(BrowseInit()) { }
~Iterator()
{
BrowseFree(_handle);
}

it begin() const
{
return it(this);
}
it end() const
{
return it(this, 0);
}

private:

void* _handle;
};

Обновление: настройка iterator_traits за it

template <> std::iterator_traits<Iterator::it>
{
typedef int difference_type;
typedef int value_type;
typedef int* pointer;
typedef int& reference;
typedef std::forward_iterator_tag iterator_category;
};

Спасибо за предложение, Якк.

Обновление 2

Вместо того, чтобы специализироваться std::iterator за Iterator::itвыводить Iterator::it от std::iterator,

class it : public std::iterator<std::forward_iterator_tag, int, int>
{
....
};
1

Другие решения


По вопросам рекламы [email protected]