帶有元素刪除的安全地圖迭代
使用地圖時,您可能會遇到需要在迭代元素時刪除元素的情況。但是,直接在循環中使用映射的擦除()方法可能會使迭代器無效。為了避免此問題,請採用以下習慣用法:
for (auto it = m.cbegin(); it != m.cend() /* not hoisted */; /* no increment */) { if (must_delete) { m.erase(it++); // or "it = m.erase(it)" since C++11 } else { ++it; } }
此習慣用法使用非基於範圍的 for 迴圈直接修改容器。透過僅在不應刪除元素時在循環內遞增迭代器,我們可以保持迭代的完整性。
請注意,在C 11 之前,擦除const 迭代器需要稍微不同的語法:
for (std::map<K,V>::iterator it = m.begin(); it != m.end(); ) { /* ... */ }
請記住,刪除元素並不違反常數性,因為const 元素仍然可以停止存在。
以上是在 C 中迭代時如何安全地從映射中刪除元素?的詳細內容。更多資訊請關注PHP中文網其他相關文章!