C++中vector模擬實現(xiàn)中的迭代器失效問題
首先來看一組代碼:
iterator insert(iterator pos, const T& x) { // 擴(kuò)容 if (_finish == _end_of_storage) { size_t len = pos - _stare; reserve(capacity() == 0 ? 4 : capacity() * 2); pos = _stare + len; } iterator end = _finish - 1; while (end >= pos) { *(end + 1) = *end; --end; } *pos = x; ++_finish; return pos; }
這是關(guān)于實現(xiàn)insert函數(shù)的一組代碼。對pos迭代器指向的位置進(jìn)行插入數(shù)據(jù)?,F(xiàn)在給出一組測試用例:
void test_vector2() { std::vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); v.push_back(4); v.push_back(5); Cao::print_container(v); /*v.insert(v.begin() + 2, 30); print_vector(v);*/ int x; cin >> x; auto p = find(v.begin(), v.end(), x); if (p != v.end()) { p = v.insert(p, 40); (*(p + 1)) *= 10; } Cao::print_container(v); }
來看運(yùn)行結(jié)果:
p本來指向的是1的位置,但是現(xiàn)在卻是40乘10,這就是因為迭代器失效的原因。當(dāng)進(jìn)行insert插入之后返回的迭代器已經(jīng)不指向原來的位置。所以對insert插入之后的pos迭代器進(jìn)行操作就會引起指向錯誤。所以得出,經(jīng)過insert之后的迭代器就會失效。不要直接進(jìn)行訪問。如若訪問,一定要更新失效的迭代器之后在進(jìn)行訪問。
修改后的代碼:
void test_vector2() { std::vector<int> v; v.push_back(1); v.push_back(2); v.push_back(3); v.push_back(4); v.push_back(5); Cao::print_container(v); int x; cin >> x; auto p = find(v.begin(), v.end(), x); if (p != v.end()) { p = v.insert(p, 40); (*(p + 1)) *= 10; } Cao::print_container(v); }
對p這個迭代器進(jìn)行修正,就得出了想要的結(jié)果。
因此在平時使用vector時,需要特別注意此類迭代器失效問題,因此的運(yùn)行錯誤。
到此這篇關(guān)于C++中vector模擬實現(xiàn)中的迭代器失效問題的文章就介紹到這了,更多相關(guān)C++ vector迭代器失效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++類繼承之子類調(diào)用父類的構(gòu)造函數(shù)的實例詳解
這篇文章主要介紹了C++類繼承之子類調(diào)用父類的構(gòu)造函數(shù)的實例詳解的相關(guān)資料,希望通過本文大家能夠掌握C++類繼承的相關(guān)知識,需要的朋友可以參考下2017-09-09深入解析C++11?lambda表達(dá)式/包裝器/線程庫
這篇文章主要介紹了C++11?lambda表達(dá)式/包裝器/線程庫的相關(guān)知識,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05Qt實現(xiàn)數(shù)據(jù)進(jìn)行加密、解密的步驟
本文主要介紹了Qt實現(xiàn)數(shù)據(jù)進(jìn)行加密、解密的步驟,包含QCryptographicHash和Qt-AES兩種庫的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-03-03詳談C++ socket網(wǎng)絡(luò)編程實例(2)
這篇文章主要為大家介紹了C++ socket網(wǎng)絡(luò)編程實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-11-11