简体   繁体   English

将我的自定义迭代器与 stl 算法结合使用

[英]Using my custom iterator with stl algorithms

I'm trying to create my own iterator, and I've got it working as expected with the std::generate algorithm.我正在尝试创建自己的迭代器,并且使用 std::generate 算法使其按预期工作。 However, when I try std::max_element of std::find, I get some cryptic errors.但是,当我尝试 std::find 的 std::max_element 时,会遇到一些神秘的错误。

Here is the interface for my iterator:这是我的迭代器的接口:

template <typename GridT, 
          typename GridPtr,
          typename GridRef,
          template <typename> class ShapeT>
class GridIterator
{
public:
    typedef GridIterator<GridT, GridPtr, GridRef, ShapeT> Iterator;

    // Iterator traits - typedefs and types required to be STL compliant
    typedef std::ptrdiff_t           difference_type;
    typedef typename GridT::Element  value_type;
    typedef typename GridT::Element* pointer;
    typedef typename GridT::Element& reference;
    typedef size_t                   size_type;
    std::forward_iterator_tag        iterator_category;


    GridIterator(GridT& grid,
                 ShapeT<typename GridT::Resolution> shape,
                 Index iterStartIndex);

    ~GridIterator();

    Iterator& operator++();
    Iterator  operator++(int);

    typename GridT::Element& operator*();
    typename GridT::Element* operator->();

    bool operator!=(const GridIterator& rhs) const;
    bool operator==(const GridIterator& rhs) const; 
    ....

} }

Using std::find, I get this error使用 std::find,我收到此错误

In file included from /usr/include/c++/4.6/algorithm:63:0, from ./grid/Map_Grid.h:11, from main.cpp:4: /usr/include/c++/4.6/bits/stl_algo.h: In function '_IIter std::find(_IIter, _IIter, const _Tp&) [with _IIter = Map::GridIterator, Map::Grid*, Map::Grid&, Map::Rectangle>, _Tp = int]': main.cpp:103:50: instantiated from here /usr/include/c++/4.6/bits/stl_algo.h:4404:45: error: no matching function for call to '__iterator_category(Map::GridIterator, Map::Grid*, Map::Grid&, Map::Rectangle>&)' /usr/include/c++/4.6/bits/stl_algo.h:4404:45: note: candidate is: /usr/include/c++/4.6/bits/stl_iterator_base_types.h:202:5: note: template typename std::iterator_traits::iterator_category std::__iterator_category(const _Iter&)在 /usr/include/c++/4.6/algorithm:63:0、./grid/Map_Grid.h:11、main.cpp:4 包含的文件中:/usr/include/c++/4.6/bits/stl_algo。 h: 在函数 '_IIter std::find(_IIter, _IIter, const _Tp&) [with _IIter = Map::GridIterator, Map::Grid*, Map::Grid&, Map::Rectangle>, _Tp = int]': main.cpp:103:50: 从这里实例化 /usr/include/c++/4.6/bits/stl_algo.h:4404:45: 错误: 没有匹配的函数调用 '__iterator_category(Map::GridIterator, Map::Grid *, Map::Grid&, Map::Rectangle>&)' /usr/include/c++/4.6/bits/stl_algo.h:4404:45: 注意:候选是:/usr/include/c++/4.6/bits/ stl_iterator_base_types.h:202:5:注:模板类型名 std::iterator_traits::iterator_category std::__iterator_category(const _Iter&)

With std::max_element :使用 std::max_element :

In file included from /usr/include/c++/4.6/bits/char_traits.h:41:0, from /usr/include/c++/4.6/ios:41, from /usr/include/c++/4.6/ostream:40, from /usr/include/c++/4.6/iostream:40, from ./grid/Map_GridIterator.h:7, from ./grid/Map_Grid.h:8, from main.cpp:4: /usr/include/c++/4.6/bits/stl_algobase.h: In function 'const _Tp& std::max(const _Tp&, const _Tp&) [with _Tp = Map::GridIterator, Map::Grid*, Map::Grid&, Map::Rectangle>]': main.cpp:102:60:在 /usr/include/c++/4.6/bits/char_traits.h:41:0、/usr/include/c++/4.6/ios:41、/usr/include/c++/4.6/ostream:40 包含的文件中, 来自 /usr/include/c++/4.6/iostream:40, 来自 ./grid/Map_GridIterator.h:7, 来自 ./grid/Map_Grid.h:8, 来自 main.cpp:4: /usr/include/c++ /4.6/bits/stl_algobase.h:在函数'const _Tp& std::max(const _Tp&, const _Tp&) [with _Tp = Map::GridIterator, Map::Grid*, Map::Grid&, Map::Rectangle> ]': main.cpp:102:60:
instantiated from here /usr/include/c++/4.6/bits/stl_algobase.h:215:7: error: no match for 'operator<' in '__a < __b' /usr/include/c++/4.6/bits/stl_algobase.h:215:7: note: candidates are: /usr/include/c++/4.6/bits/stl_pair.h:207:5: note: template constexpr bool std::operator<(const std::pair<_T1, _T2>&, const std::pair<_T1, _T2>&) /usr/include/c++/4.6/bits/stl_iterator.h:291:5: note: template bool std::operator<(const std::reverse_iterator<_Iterator>&, const std::reverse_iterator<_Iterator>&) /usr/include/c++/4.6/bits/stl_iterator.h:341:5: note: template bool std::operator<(const std::reverse_iterator<_IteratorL>&, const std::reverse_iterator<_IteratorR>&) /usr/include/c++/4.6/bits/stl_iterator.h:1049:5: note: template bool std::operator<(const std::move_iterator<_IteratorL>&, const std::move_iterator<_IteratorR>&) /usr/include/c++/4.6/bits/stl_iterator.h:1055:5: note: template bool std::operator<(const std::move_iterator<_Iterator>&, const std::move_iterator<_Iterator>&) /usr/include/从这里实例化 /usr/include/c++/4.6/bits/stl_algobase.h:215:7: 错误:'__a < __b' /usr/include/c++/4.6/bits/stl_algobase 中的 'operator<' 不匹配。 h:215:7:注意:候选是:/usr/include/c++/4.6/bits/stl_pair.h:207:5:注意:模板 constexpr bool std::operator<(const std::pair<_T1, _T2 >&, const std::pair<_T1, _T2>&) /usr/include/c++/4.6/bits/stl_iterator.h:291:5: 注意:模板 bool std::operator<(const std::reverse_iterator< _Iterator>&, const std::reverse_iterator<_Iterator>&) /usr/include/c++/4.6/bits/stl_iterator.h:341:5: 注意:模板 bool std::operator<(const std::reverse_iterator<_IteratorL >&, const std::reverse_iterator<_IteratorR>&) /usr/include/c++/4.6/bits/stl_iterator.h:1049:5: 注意:模板 bool std::operator<(const std::move_iterator<_IteratorL> &, const std::move_iterator<_IteratorR>&) /usr/include/c++/4.6/bits/stl_iterator.h:1055:5: 注意:模板 bool std::operator<(const std::move_iterator<_Iterator>& , const std::move_iterator<_Iterator>&) /usr/include/ c++/4.6/bits/basic_string.h:2510:5: note: template bool std::operator<(const std::basic_string<_CharT, _Traits, _Alloc>&, const std::basic_string<_CharT, _Traits, _Alloc>&) /usr/include/c++/4.6/bits/basic_string.h:2522:5: note: template bool std::operator<(const std::basic_string<_CharT, _Traits, _Alloc>&, const _CharT*) /usr/include/c++/4.6/bits/basic_string.h:2534:5: note: template bool std::operator<(const _CharT*, const std::basic_string<_CharT, _Traits, _Alloc>&) /usr/include/c++/4.6/bits/stl_vector.h:1290:5: note: template bool std::operator<(const std::vector<_Tp, _Alloc>&, const std::vector<_Tp, _Alloc>&) /usr/include/c++/4.6/tuple:586:5: note: template bool std::operator<(const std::tuple<_TElements ...>&, const std::tuple<_Elements ...>&) c++/4.6/bits/basic_string.h:2510:5:注意:模板 bool std::operator<(const std::basic_string<_CharT, _Traits, _Alloc>&, const std::basic_string<_CharT, _Traits, _Alloc> &) /usr/include/c++/4.6/bits/basic_string.h:2522:5: 注意:模板 bool std::operator<(const std::basic_string<_CharT, _Traits, _Alloc>&, const _CharT*) / usr/include/c++/4.6/bits/basic_string.h:2534:5:注意:模板 bool std::operator<(const _CharT*, const std::basic_string<_CharT, _Traits, _Alloc>&) /usr/include /c++/4.6/bits/stl_vector.h:1290:5:注意:模板 bool std::operator<(const std::vector<_Tp, _Alloc>&, const std::vector<_Tp, _Alloc>&) / usr/include/c++/4.6/tuple:586:5:注意:模板 bool std::operator<(const std::tuple<_TElements ...>&, const std::tuple<_Elements ...>&)

You are missing a typedef keyword for declaring an alias indicating the iterator category:您缺少用于声明指示迭代器类别的别名的typedef关键字:

// Iterator traits - typedefs and types required to be STL compliant
//...
typedef std::forward_iterator_tag iterator_category;
~~~~~~^

Without the typedef , you are actually declaring a data member.没有typedef ,您实际上是在声明数据成员。

To avoid such mistakes, you can utilize the std::iterator class template as a base class, instead of defining those aliases on your own:为避免此类错误,您可以使用std::iterator类模板作为基类,而不是自己定义这些别名:

class GridIterator : public std::iterator<std::forward_iterator_tag
                                        , typename GridT::Element>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM