
参考:(282条消息) 关于vector iterator not incrementable的解决方案_keyboardFucker的博客-优快云博客
void vector_test() {
vector<vector<Stu*>> vec;
Stu stu0 = { 10,"tom0" };
Stu stu20 = { 20,"jack0" };
Stu stu30 = { 30,"lisa0" };
Stu stu = { 1,"tom" };
Stu stu2 = { 2,"jack" };
Stu stu3 = { 3,"lisa" };
vector<Stu*> v_stu0;
v_stu0.push_back(&stu0);
v_stu0.push_back(&stu20);
v_stu0.push_back(&stu30);
vec.push_back(v_stu0);
vector<Stu*> v_stu;
v_stu.push_back(&stu);
v_stu.push_back(&stu2);
v_stu.push_back(&stu3);
vec.push_back(v_stu);
for (vector<vector<Stu*>>::iterator ite = vec.begin(); ite != vec.end(); ite++) {
//方法1 出错
for (vector<Stu*>::iterator it = ite->begin(); it != ite->end(); it++) {
if ((*it)->m_age > 2) {
ite->erase(it);//删除之后 it 会自动移动到下一个位置,如果 在for()里面又有 it++ 的话,就越界了,到了 end() 的下一个位置
}
}
//方法2 正确
//for (vector<Stu*>::iterator it = ite->begin(); it != ite->end();) {
// if ((*it)->m_age > 2) {
// it = ite->erase(it);
// }
// else {
// it++;
// }
//}
}
}
解决完了这个问题后,有出现了新的问题:

网上查 Expression: front() called on empty vector 始终找不到原因,然后在这个弹出的错误对话框选择“忽略”,错误程序定位到如下代码:

现在问题明确了,1226行的 if (ellItem->m_trackN == ite->front()->m_trackN) 语句有问题,前面通过删除二维数组里面的vector<myEllipseItem*> 里面的item的时候,有的 vEllipseItem 的成员为空,
那么判断 ite->front()->m_trackN 的时候这里调用了 font() ,但ite已经为空就不能调用,所以报错
后续的改进是先判断 ite是否为空,如下:
for (vector<vector<myEllipseItem*>>::iterator ite = vEllipseItem.begin(); ite != vEllipseItem.end(); ) {
if (ite->size() == 0)
{
ite = vEllipseItem.erase(ite);
}
else {
if (ellItem->m_trackN == ite->front()->m_trackN) {
//0x6DF0FC66 (ucrtbased.dll) (display.exe 中)处有未经处理的异常: 将一个无效参数传递给了将无效参数视为严重错误的函数。
ret = true;
retIte = ite;
}
ite++;
}
}
改完后顺利运行