У меня есть std :: vector m_vPaths; Я буду повторять этот вектор и вызывать :: DeleteFile (strPath) по мере продвижения. Если я удаляю файл успешно, я удаляю его из вектора. Мой вопрос заключается в том, можно ли обойтись без использования двух векторов? Есть ли другая структура данных, которая лучше подходит для того, что мне нужно делать?
Пример:
использование итераторов почти делает то, что я хочу, но проблема в том, что когда вы стираете, используя итератор, все итераторы становятся недействительными.
std::vector<std::string> iter = m_vPaths.begin();
for( ; iter != m_vPaths.end(); iter++) {
std::string strPath = *iter;
if(::DeleteFile(strPath.c_str())) {
m_vPaths.erase(iter);
//Now my interators are invalid because I used erase,
//but I want to continue deleteing the files remaining in my vector.
}
}
Я могу использовать два вектора, и у меня больше не будет проблем, но есть ли лучший, более эффективный способ делать то, что я пытаюсь сделать?
Кстати, если неясно, m_vPaths объявлен так (в моем классе):
std::vector<std::string> m_vPaths;