如何在迭代过程中安全地删除 std::vector 中的元素?
迭代期间从 std::vector 中删除元素:策略和性能
当需要擦除时迭代 std::vector 时对于基于条件的元素,使用带有迭代器的 for 循环的传统方法可能会遇到问题。擦除元素会使迭代器无效,从而使循环不完整。为了应对这一挑战,让我们探索处理此类场景的最佳策略。
使用失效跟踪进行迭代
一种方法是显式跟踪由擦除元素引起的迭代器失效。在提供的示例代码中:
<code class="cpp">for (iterator it = begin; it != end(container) /* !!! */; ) { if (it->somecondition()) { it = vec.erase(it); // Returns the new iterator to continue from. } else { ++it; } }</code>
登录后复制
这里的主要区别是使用 end(container) 而不是预先计算的 end,它会在每次擦除操作后更新迭代器引用。这确保了循环期间有效的迭代器比较。
组合 std::remove_if 和擦除
更有效的方法涉及组合 std::remove_if 和擦除函数。这通过消除失效跟踪的需要来优化流程:
<code class="cpp">iterator it = std::remove_if(begin, end, pred); vec.erase(it, vec.end());</code>
登录后复制
这里,pred 表示确定要删除哪些元素的删除谓词。这种方法消除了与迭代擦除相关的 O(N^2) 复杂性,并将性能提高到 O(N)。
示例应用程序
在提供的代码示例中, RemoveTimedEvent 结构体用作删除谓词,用于识别和删除与定时事件向量中的特定小部件关联的事件。
通过利用其中一种策略,您可以在迭代,同时保持正确的迭代器功能和性能。
以上是如何在迭代过程中安全地删除 std::vector 中的元素?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前
By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保护它?
3 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)