C++容器的迭代器失效

本文探讨了在C++编程中,如何处理迭代器失效的问题,特别是在向容器如vector、deque、list等添加或删除元素时。对于vector和deque,插入或删除后迭代器可能失效,而list则能保持迭代器有效。强调了在循环中插入元素时,必须更新迭代器以避免死循环。给出了实例代码来展示正确的迭代器管理和容器操作方式。
摘要由CSDN通过智能技术生成

迭代器失效

添加/删除元素可能会使迭代器失效

insert 或 push操作都可能导致迭代器 失效。

  • 对于vector和string,添加/删除元素位置之后的迭代器失效。
  • 对于deque,插入到除了首尾位置之后元素的迭代器、指针、引用都会失效。
  • 对于list、forward_list不会失效,因为加入了新元素之后,迭代器会进行更新。

当编写循环将元素插入到vector或者deque容器时,程序必须保证迭代器在每次循环后都得到更新。

重定位迭代器

在进行了添加或者删除之后,程序员需要自己进行迭代器的更新。

// 要求:若是奇数元素,则复制,否则,删除偶数元素
vector<int> vi = {1,2,3,4,5,6,7,8,9};
auto iter = vi.begin();
while(iter != vi.end()){
	if(*iter % 2 ==1){
		iter = vi.insert(iter, *iter);
		iter += 2;
	}
	else{
		iter = vi.erase(iter);//iter指向我们删除之后的元素
	}
}

在这个代码里面,添加了元素之后,end()肯定会变化,而last = v.end(),last这个迭代器却没有变化,导致了存储在last中的迭代器失效。last不再指向的v的最后一个元素了。

不要保存end的迭代器
vector<int> v;
auto begin = v.begin(), end = v.end();
while (begin != end) {
	++begin;
	begin = v.insert(begin, 42);
	++begin;
}

当加了insert之后,end这个迭代器就失效了,它不是指向v中的任何元素,而是指向了v中尾元素之后的位置。因此这个代码会陷入死循环。

所以正确做法是

while(begin != v.end()){
	++begin;
	begin = v.insert(begin, 42);
	++begin;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值