(1)对于节点式容器(map, list, set)元素的删除,插入操作会导致指向该元素的迭代器失效,其他元素迭代器不受影响; (2)对于顺序式容器(vector,string,deque)元素的删除、插入操作会导致指向该元素以及后面的元素的迭代器失效。 所以,在删除一个元素的时候,是没有什么问题的。即: for(map::iterator it=countMap.b...
某次笔试, 我遇到这样一个题目: 删除map<int, int>中value为5的倍数的元素。 该题看起来很自然很简单, 实则有迭代器失效的陷阱。 如果对迭代器失效问题一无所知, 则很容易写出如下的错误代码: 1. #include <iostream> 2. #include <map> 3. using namespace std; 4. 5. typedef map<int, int> Map...
erase迭代器只是被删元素的迭代器失效,但是返回值为void, 所以要采用erase(iter++)的方式删除迭代器, 正确方法为:: for( iter = c.begin(); iter != c.end(); ) c.erase(iter++);
在一个map中寻找值为xxx的项并删除。但是实际上这个代码是完全错误的,会导致无法预料的结果。问题就在#1处。因 此就可以这样做(《C++Standard Library》上建议的正确做法):程序代码for(auto iter1 = theMap.begin(); iter1 != theMap.end(); ){if(iter1->second == xxx){theMap.erase(...
list_my.erase(iter_list++); 或者 //iter_list=list_my.erase(iter_list); else iter_list++; printf("run over"); return 0; 以上就是小编为大家带来的vector list map 遍历删除制定元素 防止迭代器失效的实例全部内容了,希望大家多多支持我们~
vector list map 遍历删除制定元素 防止迭代器失效的实例 方法如下所示: // k_control.cpp : 定义控制台应用程序的入口点。 // #include “stdafx.h” #include “stdio.h” #include#include#include#includeusing namespace std; int _tmain(int argc, _TCHAR* argv[]) { printf(“run main”); vecto...
方法如下所示: // k_control.cpp : 定义控制台应用程序的入口点。 // #include “stdafx.h” #include “stdio.h” #include <vector> #include <map> #include <string> #include <list> using namespace std; int _tmain(int argc, _TCHAR* argv[]) { printf(“run main”); vector<int> vect...
如果你在不知情的情况下使用了失效的迭代器,后果是不可预料的。可能程序立即崩掉,也可能什么事都没有发生。崩掉了算你 幸运,因为你至少知道出了问题,不然有你受的。回到正题,我想说什么呢?比如:程序代码map<string,int> theMap;// add something to theMap...for(auto iter1 = theMap....