C++ STL list 遍歷刪除出錯解決方案
C++ STL list 遍歷刪除崩潰
錯誤用法一
下面這種用法會在for的地方崩潰,分析 第一次for循環(huán)的時候 it=0,當t.erase(it)執(zhí)行完成之后 it就變成了 -17891602
表明it不能再作為迭代器進行運算,自然會報錯。
#include <map> #include <list> using namespace std; typedef std::list<int > TESTLIST; int _tmain(int argc, _TCHAR* argv[]) { TESTLIST t; for (int i = 0; i < 10;i++) { t.push_back(i); } for (TESTLIST::iterator it = t.begin(); it != t.end();) { t.erase(it); it++; } return 0; }
錯誤用法二
下面這種用法出現(xiàn)的錯誤與錯誤一相同
#include <map> #include <list> using namespace std; typedef std::list<int > TESTLIST; int _tmain(int argc, _TCHAR* argv[]) { TESTLIST t; for (int i = 0; i < 10;i++) { t.push_back(i); } for (TESTLIST::iterator it = t.begin(); it != t.end();it++) { t.erase(it); } return 0; }
錯誤用法三
下面這種用法以為不it++就不會有事,其實他們的錯誤都一樣,那就是t.erase(it)之后 it已經(jīng)是非迭代量,自然不能作為迭代操作
#include "stdafx.h" #include <map> #include <list> using namespace std; typedef std::list<int > TESTLIST; int _tmain(int argc, _TCHAR* argv[]) { TESTLIST t; for (int i = 0; i < 10;i++) { t.push_back(i); } for (TESTLIST::iterator it = t.begin(); it != t.end();) { t.erase(it); } return 0; }
正確用法
#include <map> #include <list> using namespace std; typedef std::list<int > TESTLIST; int _tmain(int argc, _TCHAR* argv[]) { TESTLIST t; for (int i = 0; i < 10;i++) { t.push_back(i); } for (TESTLIST::iterator it = t.begin(); it != t.end();) { t.erase(it++); } return 0; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C++實現(xiàn)LeetCode(88.混合插入有序數(shù)組)
這篇文章主要介紹了C++實現(xiàn)LeetCode(88.混合插入有序數(shù)組),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07