No código a seguir, percorro um mapa e testo se um elemento precisa ser apagado. É seguro apagar o elemento e manter a iteração ou preciso coletar as chaves em outro contêiner e fazer um segundo loop para chamar erase ()?
map<string, SerialdMsg::SerialFunction_t>::iterator pm_it;
for (pm_it = port_map.begin(); pm_it != port_map.end(); pm_it++)
{
if (pm_it->second == delete_this_id) {
port_map.erase(pm_it->first);
}
}
ATUALIZAÇÃO: Obviamente, eu li essa pergunta que não achei que fosse relacionada, mas responde minha pergunta.
std::remove_if
não funciona comstd:map
Respostas:
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.
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.
fonte
pm_it++
garantida para ser executada antes da entrada da função?Sequence
contêineres. A propriedade especial dosAssociative
contêineres é que os iteradores não são invalidados por apagar ou inserir (a menos que aponte para o elemento que foi apagado). Vector e apaga iteradores de design de usuário são abordados detalhadamente na pergunta apropriada stackoverflow.com/a/3938847/14065Aqui está como eu faço isso ...
fonte
É assim que eu faria, aproximadamente:
Há algo estranho sobre
mas apenas copiei do seu código de exemplo.
fonte