C ++惯用方式在本身正在被修改的容器上进行迭代

问题描述

我发现自己遍历正在循环内修改的容器X。但是在每次迭代中,都需要未修改的X:

for (int x : X) { // wrong,container X in iteration should be the "original"
    modify_X();  // X modified here
}

一种解决方案是遍历副本

containerT X_copy(X);
for (int x : X_copy) {
    modify_X();   
}

for (int x : containerT {X}) {
    modify_X();   
}

是否有惯用的方法

解决方法

问题中的最后一个例子看起来最简单。但是,从C ++ 20开始,您也可以这样做:

for (auto copy = X; int i : copy)
{
  modify_X();
}

这里是demo

请注意,在您的第一个代码段中,这不仅在逻辑上是错误的,而且还会在您修改要迭代的范围时调用未定义的行为。