vector中erase的两种常见错误

//在循环中使用erase需要避免的错误

//erase的函数原型有两种形式:
//iterator erase(iterator position);
//iterator erase(iterator first, iterator last); 左闭右开 [first,last)

vector<int> v1 = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 9, 9, 10, 9 };

错误示例1

for (auto p1 = v1.begin(); p1 != v1.end();p1++)
{
    if (*p1 == 9)
    {
        v1.erase(p1);
    }
}

//p1被erase以后,变成了一个“野迭代器”,对其进行++操作会发生未定义的错误

Return value
An iterator pointing to the new location of the element that followed the last element erased by the function call. This is the container end if the operation erased the last element in the sequence.

会返回指向删掉的元素后面第一个元素的迭代器,如果删掉的是最后一个元素,返回end()

错误示例2

for (auto p1 = v1.begin(); p1 != v1.end();p1++)
{
    if (*p1 == 9)
    {
        p1=v1.erase(p1);
    }
}

1)无法删除两个连续的9: 由于erase会返回指向下一个元素的迭代器,因此会跳过一个元素
2)当9位于vector最后位置的时候,也会出错,erase操作后p1指向end()(循环体第3个参数:在ve.end()上执行 ++ 操作会超过end(),无定义,报错)

正确示例

for (auto p1 = v1.begin(); p1 != v1.end();)
{
    if (*p1 == 9)
    {
        p1=v1.erase(p1);
    }
    else
    {
        p1++;
    }
}
转:https://segmentfault.com/a/1190000016096696
  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值