C ++ 11
Это исправлено в C ++ 11 (или стирание было улучшено / согласовано для всех типов контейнеров).
Метод erase теперь возвращает следующий итератор.
auto pm_it = port_map.begin();
while(pm_it != port_map.end())
{
if (pm_it->second == delete_this_id)
{
pm_it = port_map.erase(pm_it);
}
else
{
++pm_it;
}
}
C ++ 03
Стирание элементов на карте не делает недействительными никакие итераторы.
(кроме итераторов на удаленном элементе)
Фактически вставка или удаление не делает недействительным ни одного из итераторов:
Также смотрите этот ответ:
Mark Ransom Technique
Но вам нужно обновить код:
В вашем коде вы увеличиваете pm_it после вызова erase. В этот момент уже слишком поздно и он уже признан недействительным.
map<string, SerialdMsg::SerialFunction_t>::iterator pm_it = port_map.begin();
while(pm_it != port_map.end())
{
if (pm_it->second == delete_this_id)
{
port_map.erase(pm_it++); // Use iterator.
// Note the post increment.
// Increments the iterator but returns the
// original value for use by erase
}
else
{
++pm_it; // Can use pre-increment in this case
// To make sure you have the efficient version
}
}