- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在生成和比较 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。我试图通过将“它”的类型声明更改为自动来修复它,但在尝试与 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));
关于c++ - 使用 boost::multi_index reverse_iterators,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36541100/
让它成为 std::list::iterator 和 std::list::reverse_iterator。反向是从正向派生的吗?如果不是,那么为什么 list 的成员函数没有反向等价物? 提前致谢
这个问题在这里已经有了答案: 关闭10 年前。 Possible Duplicate: Why does a push_back on an std::list change a reverse i
我有一个包含和管理一系列对象的类。为了避免泄露这些对象的存储方式,同时允许迭代它们,我决定使用 boost::any_iterator 进行类型删除。 using my_erased_type_it
关于 the cppreference page of reverse_iterator我发现以下评论 std::reverse_iterator does not work with iterato
我正在尝试为我的迭代器和 const_iterator 类实现反向迭代器适配器,但遇到了一些麻烦。如果有人可以指导我解决这个问题,将不胜感激! 我的想法是我应该能够从我的 rbegin() 和 ren
我正在尝试编写包含一些遗留代码的二次算法。我想两次穿过一个特定的容器,一次按顺序,一次按相反的顺序。显然,我的第一个想法是使用 iterator 和 reverse_iterator,但奇怪的是,我正
有没有办法检查作为 arg 传递给 fnc 的迭代器是否是 reverse_iterator?我可以使用任何迭代器特征函数吗? 最佳答案 用偏特化来写很简单: #include #include
这是使用 std::reverse_iterator 的代码示例: template class Stack { T arr[SIZE]; size_t pos = 0; public
我正在尝试使用该算法构建哈夫曼树,但我已经走到了某种死胡同。我首先将字符串作为用户输入,然后找到输入的实际位表示以与压缩位序列进行比较。然后我使用 std::map 将字母映射到它们的频率。现在我要做
我天真地期望这个程序能够编译并运行成功: #include #include int main() { const std::string s = "foo"; auto forw
最近我在维护的代码中发现了以下内容: for (reverse_iterator rit = base_container::rbegin(); rit != base_container::rend
我正在将两个现有函数转换为模板,这两个函数检查迭代器是否是 std::map 中的最后一项和倒数第二项。 isLastItem 模板编译,isSecondLastItem 失败并出现我不理解的错误消息
我刚刚学习 STL,reverse_iterator 让我感到困惑。它有一个默认构造函数,但我不知道如何使用它。我试过: reverse_iterator r{}; r --; 然后程序崩溃了。我认为
我在使用 gcc 的非 const 容器上使用 const 反向迭代器时遇到问题。好吧,只有某些版本的 gcc。 #include #include using namespace std; in
最近,用户@Mooing Duck 设计了concatenated_range ,一个优雅的自定义迭代器,解决了“链接”两个迭代器的问题,一切都在幕后。 它非常适合预期用途: auto range0=
我实现了一个双向迭代器,但它不是对数据结构进行操作,而是返回一个可以在两个方向上迭代计算的数学序列。事实上,我正在迭代整数,使用++ 和 -- 在 int 上。这意味着数据不会存储在不同的结构中,因此
这个问题在这里已经有了答案: Can I convert a reverse iterator to a forward iterator? (5 个答案) 关闭 4 年前。 我想在 for 循环中
似乎迭代器适配器 reverse_iterator 双重定义了它的大部分嵌套类型。特别是,它公开继承自 std::iterator,它公开了 iterator_category、value_type、
我有一个方法应该迭代 map向前或向后,取决于条件。操作本身与方向无关,因此我希望能够做这样的事情: std::map some_map; auto iter = some_condition ? s
boost 的文档 specialized iterator adaptors声明 boost::reverse_iterator “纠正了 C++98 的 std::reverse_iterator
我是一名优秀的程序员,十分优秀!