C ++ 11
Isso foi corrigido no C ++ 11 (ou a eliminação foi aprimorada / tornada consistente em todos os tipos de contêiner).
O método apagar agora retorna o próximo iterador.
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
A exclusão de elementos em um mapa não invalida nenhum iterador.
(além dos iteradores no elemento que foi excluído)
Na verdade, inserir ou excluir não invalida nenhum dos iteradores:
Veja também esta resposta:
Mark Ransom Technique
Mas você precisa atualizar seu código:
no seu código, você incrementa pm_it depois de chamar apagar. Neste ponto, é tarde demais e já está invalidado.
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
}
}
std::remove_if
não funciona comstd:map