正确处理列表大小为1的std :: list擦除

问题描述

|| 考虑以下:
for (it = list.begin(); it != list.end(); ++it) {
    if (!(*it)->alive) {
        it = list.erase(it);
    }
}
只要
list.size() > 1
就可以正常工作。一旦列表仅包含一个元素,就调用擦除段错误。我假设是因为没有下一个元素。至少,这是我正在观察的行为。 有没有正确的方法解决这个问题?也许是完全不同的方法? 如您所见,我不想立即清除列表。我只想在元素消失时删除它们,并且在删除最后一个元素之前效果很好。     

解决方法

        以下将正常工作:
for (it = list.begin(); it != list.end(); ) {
    if (!(*it)->alive) {
        it = list.erase(it);
    } else {
        ++it;
    }
}
问题不仅仅在于某些尺寸。在您的示例中,您每次删除一个元素时都会跳过它。想一想。 如果元素不是\“ alive \”,则执行:
it = list.erase(it);
,该元素将删除元素并将
it
设置为紧随其后的元素。然后您的循环执行
++it
,跳过下一个,可能会跳过
end()
! 这不仅是跳过ѭ6的问题,您也正在跳过其他内容,但是删除列表中的最后一个元素可能会导致崩溃。