c++ - map::erase 如何知道间隔是否有效?

标签 c++ dictionary iterator erase

我正在编写一个简单的程序,它使用了 std::map::erase .
该程序很好,但有一些我不明白的地方。
如果我传给 erase function 第一个迭代器超出第二个迭代器的间隔,该函数不会删除任何内容。这很好。
另一方面,如果我使用 std::distance第一个迭代器超出第二个迭代器,此函数“失败”。我知道这是由于 map 迭代器的性质,例如 std::vector没有这个问题。
但我不明白如何map::erase可以知道区间是否有效。

最佳答案

来自 std::distance 's specification :

The behavior is undefined if last is not reachable from first by (possibly repeatedly) incrementing first.


对于随机访问迭代器,C++11 之后有一个无关紧要的异常(exception),但这不适用于 map 。这是未定义的行为,因此您可以在这里得到“失败”,甚至崩溃。std::maperase()方法似乎也表明 this is undefined behavior, too :
  1. Removes the elements in the range [first; last), which must be a valid range in *this.

您传递的迭代器值不包含“有效范围”,因此这也是未定义的行为。尽管今天这似乎什么也没做,但如果下周您的代码开始崩溃,生成的代码完全在其权利范围内,因为这就是“未定义行为”的含义。
总之,erase()std::distance在这种情况下导致未定义的行为。

关于c++ - map::erase 如何知道间隔是否有效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65928514/

相关文章:

c++ - 使用 ostringstream 语法将字符串加倍

python - 从数据框列创建一个字典,该字典的单元格中有多个值

c# - 如何在某些方法中传递 Dictionary<string, string> 对象

python pandas ... pandas 中 iterrows 的替代方法来获取下一行值(新)

c++ - 一种成员数据类型不同的对象的工厂模式?

c++ - 如何改进我的功能

javascript - 遍历对象的值

c++ - 生成器列表与 C++ 标准库?

python - 斐波那契数列python

c++ - 添加(而不是连接)一个数字到 QByteArray