我在生成和比较multi_index集上的reverse_iterators时遇到了一些麻烦。

namespace mi = boost::multi_index;
typedef mi::multi_index_container<
  size_t,
  mi::indexed_by<
  mi::ordered_non_unique<mi::identity<size_t>, IndexComparator >,
  mi::hashed_unique<mi::identity<size_t> >
  >
> index_set_t;

typedef index_set_t::nth_index<0>::type index_set_by_margin_t;

void f() {
    index_set_by_margin_t& margin_index = ordered_indexes.get<0>();
    index_set_by_margin_t::reverse_iterator it =
        std::reverse_iterator<index_set_by_margin_t::iterator>
        (margin_index.lower_bound(3, cmp));
}


这在f的最后一行失败,在该行中我尝试分配反向迭代器,并带有来自g ++ 5.2.1的相当长的错误消息:

error: conversion from ‘std::reverse_iterator<boost::multi_index::detail::bidir_node_iterator<boost::multi_index::detail::ordered_index_node<boost::multi_index::detail::hashed_index_node<boost::multi_index::detail::index_node_base<long unsigned int, std::allocator<long unsigned int> >, boost::multi_index::detail::hashed_unique_tag> > > >’ to non-scalar type ‘boost::multi_index::detail::ordered_index<boost::multi_index::identity<long unsigned int>, IndexComparator, boost::multi_index::detail::nth_layer<1, long unsigned int, boost::multi_index::indexed_by<boost::multi_index::ordered_non_unique<boost::multi_index::identity<long unsigned int>, IndexComparator>, boost::multi_index::hashed_unique<boost::multi_index::identity<long unsigned int> > >, std::allocator<long unsigned int> >, boost::mpl::vector0<mpl_::na>, boost::multi_index::detail::ordered_non_unique_tag>::reverse_iterator {aka boost::iterators::reverse_iterator<boost::multi_index::detail::bidir_node_iterator<boost::multi_index::detail::ordered_index_node<boost::multi_index::detail::hashed_index_node<boost::multi_index::detail::index_node_base<long unsigned int, std::allocator<long unsigned int> >, boost::multi_index::detail::hashed_unique_tag> > > >}’ requested


似乎是在说std :: reverse_iterator没有产生正确类型的reverse_iterator。我试图通过将'it'的类型声明更改为auto来修复它,但是在尝试与margin_index.rend()比较时仍然失败

是否有某种方法可以产生与margin_index.rend()相同类型的reverse_iterator,它还可以保持Lower_bound的对数复杂性?

最佳答案

不要使用std::reverse_iterator,不需要:

index_set_by_margin_t::reverse_iterator it =
    index_set_by_margin_t::reverse_iterator(margin_index.lower_bound(3, cmp));


要么

index_set_by_margin_t::reverse_iterator it(margin_index.lower_bound(3, cmp));

07-24 13:59