如何将return一个指针作为迭代器?
How to return a pointer as an iterator?
我需要实现迭代器,但我没有时间制作漂亮的迭代器 类,所以我决定只 return 指针。是这样的
int* begin()
{
return p;
}
但我希望它们像往常一样运行 stl 迭代器
*++begin(); // doesn't work because returned pointer isn't l-value
std::vector<int> vi{ 0, 1 };
*++vi.begin(); // works fine
int* p = begin();
*++p; // works fine as well
我该怎么做?
指针do完全满足迭代器要求(指针甚至满足最专业的随机访问迭代器要求)。您的问题来自这样一个事实,即在您正在使用的标准库的实现中,例如提供的迭代器std::vector
支持比迭代器要求更多的操作。
换句话说,标准不保证++vi.begin()
将适用于std::vector
迭代器vi
。它恰好适用于您对标准库的实现,但它是一个实现细节。 不支持的迭代器仍然是一个完全有效的迭代器。
所以,回答你的问题:如果你想要一个支持所有迭代器操作的迭代器的快速替代品,你当然可以使用指针。如果你想要一个迭代器的快速替代品,除了迭代器要求之外,它还支持你的标准库实现支持的所有操作,你可能必须推出你自己的 class.
使用 boost
:
可以很容易地创建一个最小的迭代器
#include <boost/iterator/iterator_facade.hpp>
using namespace boost;
struct Int100
{
int arr[100];
struct iterator : iterator_facade<iterator,int,forward_traversal_tag>
{
iterator( int* p = nullptr ) : p(p) {}
void increment() { ++p; }
bool equal(const iterator& other) const { return p == other.p; }
int& dereference() const { return *p; }
int* p;
};
iterator begin() { return {arr}; }
iterator end() { return {arr+100}; }
};
这支持您正在寻找的 *++begin()
语法。
我需要实现迭代器,但我没有时间制作漂亮的迭代器 类,所以我决定只 return 指针。是这样的
int* begin()
{
return p;
}
但我希望它们像往常一样运行 stl 迭代器
*++begin(); // doesn't work because returned pointer isn't l-value
std::vector<int> vi{ 0, 1 };
*++vi.begin(); // works fine
int* p = begin();
*++p; // works fine as well
我该怎么做?
指针do完全满足迭代器要求(指针甚至满足最专业的随机访问迭代器要求)。您的问题来自这样一个事实,即在您正在使用的标准库的实现中,例如提供的迭代器std::vector
支持比迭代器要求更多的操作。
换句话说,标准不保证++vi.begin()
将适用于std::vector
迭代器vi
。它恰好适用于您对标准库的实现,但它是一个实现细节。 不支持的迭代器仍然是一个完全有效的迭代器。
所以,回答你的问题:如果你想要一个支持所有迭代器操作的迭代器的快速替代品,你当然可以使用指针。如果你想要一个迭代器的快速替代品,除了迭代器要求之外,它还支持你的标准库实现支持的所有操作,你可能必须推出你自己的 class.
使用 boost
:
#include <boost/iterator/iterator_facade.hpp>
using namespace boost;
struct Int100
{
int arr[100];
struct iterator : iterator_facade<iterator,int,forward_traversal_tag>
{
iterator( int* p = nullptr ) : p(p) {}
void increment() { ++p; }
bool equal(const iterator& other) const { return p == other.p; }
int& dereference() const { return *p; }
int* p;
};
iterator begin() { return {arr}; }
iterator end() { return {arr+100}; }
};
这支持您正在寻找的 *++begin()
语法。