C ++,我的程序在调用list.erase后"go",没有增量迭代器?
c++ where my program "go" after call to list.erase without increment iterator?
cpp新手。当我在迭代器上调用擦除而不递增时,我的程序会立即退出,不会出现任何符号或崩溃。在以下示例中,只打印"After if condition",而不打印任何内容。没有显示错误。但是,如果我执行正确调用来list.erase(it++);比它打印的所有。我的问题是当我认为它不正确时发生了什么。为什么我没有看到任何崩溃或退出?我担心,我问这个问题的原因是关于捕捉这种碰撞,为什么我没有在捕捉块中捕捉到它?有办法抓住它吗
int main(int argc, char *argv[]) {
try {
list<int>::iterator it;
list<int> list;
list.push_back(1);
for (it = list.begin(); it != list.end(); ++it) {
if ((*it) == 1) {
list.erase(it);
}
cerr << "After if condition " << endl;
}
cerr << "After for condition" << endl;
} catch (...) {
cerr << "catch exception" << endl;
}
cerr << "Finish" << endl;
}
来自std::list::erase()
:
对已擦除元素的引用和迭代器无效。
it
被擦除,然后被++it
使用,导致未定义的行为:这意味着任何事情都可能发生。
erase()
在最后删除的元素之后返回迭代器,这意味着您可以存储erase()
的返回值并继续,但循环需要修改,以避免在执行erase()
后跳过元素。
使用迭代器时,不能更改容器。erase
立即使迭代器无效。
你能做的是:
for( list<int>::iterator it = list.begin(); it != list.end();)
if( (*it) == 1 )
it=list.erase(it);
else
++it;
(从STL列表擦除项目)
或
for( list<int>::iterator it = list.begin(); it != list.end();)
if( (*it) == 1 )
list.erase(it++);
else
++it;
这方面有很多帖子。搜索"擦除列表迭代器"!
edit:如果不这样做,即使迭代器无效,然后递增,则行为未定义。这意味着它可能因系统而异,因编译器而异,因运行而异。
如果它没有崩溃,并且表现良好,那你就很幸运了。如果它没有崩溃并做了其他事情,那你就不走运了,因为它是一个很难找到的bug。
一旦擦除it
,就不能使用它。调用++会导致崩溃。在擦除元素之前存储下一个迭代器。
诀窍是使用erase(it++)
。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 如何在c++迭代器类型中包装std::chrono
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 对于set上的循环-获取next元素迭代器
- 为什么output_editor Concept不需要output_e迭代器标记
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器
- 不明白迭代器,引用和指针失效,一个例子
- 我可以使用反向迭代器作为ForwardIt吗
- ESP8266单片机矢量迭代器的C++问题
- 如何在C++中将迭代器作为函数参数传递
- 是否应避免从非常量迭代器转换为常量迭代器?
- 如何在 c++ 中将字符串迭代器变量传递给函数?
- 为什么 vector 的随机访问迭代器给出与指针不同的内存地址?
- C ++,我的程序在调用list.erase后"go",没有增量迭代器?