c – 为什么std :: vector :: insert在插入点之后使所有迭代器无效

当插入std :: vector时,只要容量没有用尽,C标准就确保插入点之前的所有迭代器都保持有效(参见[23.2.4.3/1]或 std::vector iterator invalidation).

在插入点保持有效(如果容量没有用尽)之后不允许迭代器的原因是什么?当然,然后他们会指向一个不同的元素,但是(从std :: vector的假定实现)它仍然可以使用这样的迭代器(例如取消引用它或递增它).

解决方法

迭代器可能引用不同的元素就足以使它们失效.迭代器应该在其有效生命周期的持续时间内引用相同的元素.

你是对的,在实践中,如果你要取消引用这样的迭代器,你可能不会遇到任何崩溃或鼻子恶魔,但这并不能使它有效.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...