首页 后端开发 C++ 在迭代期间从'std::set”中删除元素是 C 中定义的行为还是特定于实现的行为?

在迭代期间从'std::set”中删除元素是 C 中定义的行为还是特定于实现的行为?

Dec 04, 2024 am 08:30 AM

Is Deleting Elements from a `std::set` During Iteration Defined Behavior in C   or Implementation-Specific?

在迭代期间从 std::set 中删除元素:实现影响

在删除元素时迭代集合可能会带来挑战,因为操作可能会使迭代器无效。在这种情况下,问题就出现了:这种行为是由 C 标准定义的还是特定于实现的?

实现依赖

根据 C 标准(23.1 .2.8),向集合中插入元素不应影响迭代器或对容器的引用,而擦除元素仅应使迭代器和对已删除元素的引用。然而,在擦除操作期间迭代器的行为并未明确指定,使其对特定于实现的决策开放。

GCC 实现

在提供的示例代码中,使用Ubuntu 10.04 上的 GCC 4.3.3 在迭代期间从集合中删除元素不会使迭代器失效。这表明 GCC 的实现遵循更宽松的方法,允许在擦除后继续使用迭代器。

符合解决方案

为了确保标准一致性,采用不同的方法是必须的。一种常见的解决方案是在擦除元素之前创建迭代器的副本:

for (auto it = numbers.begin(); it != numbers.end(); ) {
    if (*it % 2 == 0) {
        numbers.erase(it++);
    }
    else {
        ++it;
    }
}
登录后复制

在这种情况下,后缀增量(it)将旧位置传递给erase()函数,同时跳转到下一个元素。此处首选后缀增量,因为它避免了前缀增量可能出现的潜在双增量问题(当条件为 false 时)。

C 11 Update

With C 11 的出现,提供了更优雅的解决方案。现在,erase() 函数返回一个迭代器,指向最后一个删除的元素后面的元素(如果最后一个元素被删除,则返回 set::end)。这允许更简洁的实现:

for (auto it = numbers.begin(); it != numbers.end(); ) {
    if (*it % 2 == 0) {
        it = numbers.erase(it);
    }
    else {
        ++it;
    }
}
登录后复制

以上是在迭代期间从'std::set”中删除元素是 C 中定义的行为还是特定于实现的行为?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

c语言函数返回值的类型有哪些?返回值是由什么决定的? c语言函数返回值的类型有哪些?返回值是由什么决定的? Mar 03, 2025 pm 05:52 PM

c语言函数返回值的类型有哪些?返回值是由什么决定的?

Gulc:从头开始建造的C库 Gulc:从头开始建造的C库 Mar 03, 2025 pm 05:46 PM

Gulc:从头开始建造的C库

c语言函数格式字母大小写转换步骤 c语言函数格式字母大小写转换步骤 Mar 03, 2025 pm 05:53 PM

c语言函数格式字母大小写转换步骤

c语言函数的定义和调用规则是什么 c语言函数的定义和调用规则是什么 Mar 03, 2025 pm 05:53 PM

c语言函数的定义和调用规则是什么

c语言函数返回值在内存保存在哪里? c语言函数返回值在内存保存在哪里? Mar 03, 2025 pm 05:51 PM

c语言函数返回值在内存保存在哪里?

distinct用法和短语分享 distinct用法和短语分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短语分享

如何有效地使用STL(排序,查找,转换等)的算法? 如何有效地使用STL(排序,查找,转换等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,转换等)的算法?

C标准模板库(STL)如何工作? C标准模板库(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C标准模板库(STL)如何工作?

See all articles