c++ - 你如何通过 STL 列表向后迭代?

标签 c++ list stl iterator traversal

我正在编写一些 Windows 和 Mac 之间的跨平台代码。

如果 list::end() “返回一个迭代器,该迭代器指向列表中最后一个元素之后的位置”并且可以在向前遍历列表时检查,那么向后遍历的最佳方法是什么?

此代码适用于 Mac,但不适用于 Windows(不能递减超过第一个元素):

list<DVFGfxObj*>::iterator iter = m_Objs.end();
for (iter--; iter!=m_Objs.end(); iter--)// By accident discovered that the iterator is circular ?
{
}

这适用于 Windows:

list<DVFGfxObj*>::iterator iter = m_Objs.end();
    do{
        iter--;
    } while (*iter != *m_Objs.begin());

是否有另一种可以在 for 循环中实现的向后遍历方式?

最佳答案

使用 reverse_iterator 而不是 iterator。 使用 rbegin() & rend() 而不是 begin() & end()

另一种可能性,如果您喜欢使用 BOOST_FOREACH宏是使用Boost 1.36.0中引入的BOOST_REVERSE_FOREACH宏。

关于c++ - 你如何通过 STL 列表向后迭代?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/188942/

相关文章:

c++ - 使用编译器安装库

c++ - 如何使用静态记录器设置不同的日志位置

python - 检查列表或字符串以查看是否存在来自另一个列表的字符串

php - 即使使用了 trim,也只有列表中的第一个条目进入 mysql 表 PHP

C++ 映射行为不正常

c++ - 0xC0000005 : Access violation executing location 0x00000000

C++ boost 图 : how to add_vertex via iteration

Python:按索引弹出列表列表中的项目

c++ - 如何有效地将 std::sort 与不透明数据类型一起使用?

c++ - 创建一个求和函数以仅对 vector 的一部分求和