如何将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() 语法。