C++ STL list 遍历删除出错解决方案
C++STLlist遍历删除崩溃
错误用法一
下面这种用法会在for的地方崩溃,分析第一次for循环的时候it=0,当t.erase(it)执行完成之后it就变成了-17891602
表明it不能再作为迭代器进行运算,自然会报错。
#include<map>
#include<list>
usingnamespacestd;
typedefstd::list<int>TESTLIST;
int_tmain(intargc,_TCHAR*argv[])
{
TESTLISTt;
for(inti=0;i<10;i++)
{
t.push_back(i);
}
for(TESTLIST::iteratorit=t.begin();it!=t.end();)
{
t.erase(it);
it++;
}
return0;
}
错误用法二
下面这种用法出现的错误与错误一相同
#include<map>
#include<list>
usingnamespacestd;
typedefstd::list<int>TESTLIST;
int_tmain(intargc,_TCHAR*argv[])
{
TESTLISTt;
for(inti=0;i<10;i++)
{
t.push_back(i);
}
for(TESTLIST::iteratorit=t.begin();it!=t.end();it++)
{
t.erase(it);
}
return0;
}
错误用法三
下面这种用法以为不it++就不会有事,其实他们的错误都一样,那就是t.erase(it)之后it已经是非迭代量,自然不能作为迭代操作
#include"stdafx.h"
#include<map>
#include<list>
usingnamespacestd;
typedefstd::list<int>TESTLIST;
int_tmain(intargc,_TCHAR*argv[])
{
TESTLISTt;
for(inti=0;i<10;i++)
{
t.push_back(i);
}
for(TESTLIST::iteratorit=t.begin();it!=t.end();)
{
t.erase(it);
}
return0;
}
正确用法
#include<map>
#include<list>
usingnamespacestd;
typedefstd::list<int>TESTLIST;
int_tmain(intargc,_TCHAR*argv[])
{
TESTLISTt;
for(inti=0;i<10;i++)
{
t.push_back(i);
}
for(TESTLIST::iteratorit=t.begin();it!=t.end();)
{
t.erase(it++);
}
return0;
}
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!