C++ vector一边遍历一边删除元素

本文介绍了一种使用迭代器遍历C++ STL vector容器,并在遍历过程中安全地删除某些元素的方法。通过使用`erase`函数,可以有效地移除不满足条件的对象,同时更新迭代器以指向容器中的下一个元素。
转自:


http://ecnuloveexpo.blog.163.com/blog/static/1219589962012924113456858/


使用iterator迭代器对vector进行遍历,删除元素时使用的erase函数返回的是vector中的下一个元素。


代码如下:

/* ObjectVector是一个Object类型的迭代器,轮询ObjectVector,如果Object::IsAlive()返回false则从vector中删除该Object */

vector<Object*>::iterator it = ObjectVector.begin();

while(it != ObjectVector.end()){

if((*it)->IsAlive()){

it++;

}else{

it = ObjectVector.erase(it);

}

}



C++ 中使用 `vector` 容器时,通过迭代器遍历删除元素是一个常见的操作。然而,由于 `vector` 的内存连续性特性,删除元素会导致迭代器失效,因此需要特别注意迭代器的操作顺序。 ### 使用正确的删除方式 在遍历过程中删除元素时,应避免直接调用 `erase()` 后继续使用当前迭代器进行递增操作。正确的方法是将 `erase()` 的返回值赋给迭代器,因为 `erase()` 返回指向被删除元素之后的下一个有效元素的迭代器。例如: ```cpp std::vector<int> vec; // 填充vec... for (auto it = vec.begin(); it != vec.end(); ) { if (/* 条件判断 */) { it = vec.erase(it); // erase返回下一个有效的迭代器 } else { ++it; // 只有不删除元素时才递增迭代器 } } ``` 这种方法可以确保迭代器始终指向一个有效的元素[^1]。 ### 避免错误的删除方式 一种常见的错误是在删除元素后继续使用原来的迭代器。例如,以下代码存在逻辑错误: ```cpp std::vector<int>::iterator it = vec.begin(); for (; it != vec.end();) { std::vector<int>::iterator tmpit = it; it++; vec.erase(tmpit); } ``` 这段代码虽然在某些情况下可能运行正常,但在特定条件下(如删除最后一个元素)可能会导致未定义行为,因为 `erase()` 调用会使传入的迭代器失效[^1]。 ### 结合条件判断的删除方法 如果需要根据特定条件删除元素,可以在循环内部加入条件判断语句。例如,假设要删除所有等于某个值的元素: ```cpp std::vector<int> vec = {1, 2, 3, 4, 5, 6}; int value_to_remove = 3; for (auto it = vec.begin(); it != vec.end(); ) { if (*it == value_to_remove) { it = vec.erase(it); // 删除元素并更新迭代器 } else { ++it; // 仅当不删除元素时递增迭代器 } } ``` 此方法确保每次调用 `erase()` 后迭代器都能正确指向下一个有效元素,从而避免了迭代器失效的问题[^1]。 ### 使用标准库算法简化操作 C++ 标准库提供了 `std::remove_if` 算法,可以与 `vector` 的 `erase` 方法结合使用来高效地删除符合条件的元素: ```cpp #include <algorithm> vec.erase(std::remove_if(vec.begin(), vec.end(), [](int val) { return val == value_to_remove; // 指定删除条件 }), vec.end()); ``` 这种方式不仅简洁,而且能够很好地表达意图,推荐用于需要删除多个符合条件元素的情况[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值