- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个包含和管理一系列对象的类。为了避免泄露这些对象的存储方式,同时允许迭代它们,我决定使用 boost::any_iterator
进行类型删除。
using my_erased_type_iterator = boost::range_detail::any_iterator<
MyClass,
boost::bidirectional_traversal_tag,
MyClass&,
std::ptrdiff_t>;
我在MyClass
中定义了一个函数Begin()
和End()
,它简单的返回容器的begin()
和 end()
用作 my_erased_type_iterator
。它完全按照我的意愿工作,MyClass
之外的任何人都不知道我正在使用 vector 来存储对象,除了我在 Myclass 中公开的函数之外,他们也无法访问容器
的界面。
现在,出于多种原因,我需要对对象进行反向迭代。我还需要知道反向迭代器之后的下一个元素(类似于在普通迭代器上调用 std::next()
,这对于反向迭代器来说已经不是那么简单了),我可能还需要在该反向迭代器上调用类似 erase()
的函数。
所以对于我的问题:是否有一种优雅的方式来使用类型删除和反向迭代器(以及正向和反向的 const 版本)?我应该使用前向类型删除迭代器并向后迭代吗?我突然想到我可能以错误的方式解决了这个问题,所以我愿意接受任何建议或在需要时澄清我的问题。
最佳答案
请注意 any_iterator
是一个实现细节。
我会先回答你的直接问题,然后用 any_range<>
展示方法正如 Boost Range 的公共(public) API 所预期的那样。
make_reverse_iterator
您可以简单地使用 make_reverse_iterator
设施来自
#include <boost/range.hpp>
#include <boost/range/any_range.hpp>
struct MyClass {
int i;
};
using my_erased_type_iterator = boost::range_detail::any_iterator<
MyClass,
boost::bidirectional_traversal_tag,
MyClass&,
std::ptrdiff_t>;
#include <iostream>
#include <vector>
int main() {
using namespace boost;
std::vector<MyClass> const v { {1}, {2}, {3}, {4} };
for (auto& mc : make_iterator_range(
make_reverse_iterator(v.end()),
make_reverse_iterator(v.begin())))
{
std::cout << mc.i << " ";
}
}
打印
4 3 2 1
reversed
范围适配器:或者,您可以使用全范围样式并使用 any_range<>
:
int main() {
std::vector<MyClass> const v { {1}, {2}, {3}, {4} };
boost::any_range_type_generator<decltype(v)>::type x = reverse(v);
for (my_erased_type_const_iterator f = boost::begin(x), l = boost::end(x); f!=l; ++f) {
std::cout << f->i << " ";
}
}
关于c++ - 使用带有类型删除的 reverse_iterator,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35025489/
让它成为 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
我是一名优秀的程序员,十分优秀!