无法删除指针的向量

Jam*_*ond 3 c++ pointers vector delete-operator

我有一个管理器类,它包含一个指向虚拟基类的指针向量,允许在那里存储各种子类.在这个管理器类的析构函数中,我希望它循环遍历它所拥有的所有指针并删除它们.但是,我尝试了许多方法,程序在执行过程中不断崩溃.

我现有的代码如下所示: -

for (std::vector<GameState*>::iterator it = gamestates_.begin(); it != gamestates_.end(); ++it){
    delete *it;
    it = gamestates_.erase(it);
}
Run Code Online (Sandbox Code Playgroud)

我还没有尝试过的一件事是使用unique_ptr,但我确信这应该能够在不使用它们的情况下处理它.如果我错了,请纠正我.

编辑:我知道我应该在循环之后清除向量,但这是我在尝试删除指针的每个常规方法后所得到的.它似乎不喜欢删除命令.

Mik*_*our 5

从向量中删除元素会使迭代器无效,因此您无法继续迭代.在这种情况下,我不会擦除循环中的元素; 之后我会清除矢量:

for (auto it = gamestates_.begin(); it != gamestates_.end(); ++it){
    delete *it;
}
gamestates_.clear();
Run Code Online (Sandbox Code Playgroud)

虽然,如果这是在析构函数中并且矢量即将被销毁,那么也没有必要清除它.

如果你确实需要在循环中擦除(也许是因为你只想删除一些元素),那么你需要更加小心以保持迭代器有效:

for (auto it = gamestates_.begin(); it != gamestates_.end();){ // No ++ here
    if (should_erase(it)) {
        it = gamestates_.erase(it);
    } else {
        ++it;
    }
}
Run Code Online (Sandbox Code Playgroud)

我还没有尝试过的一件事是使用,unique_ptr但我确信这应该能够在不使用它们的情况下处理它.如果我错了,请纠正我.

如果你确实希望通过蒸汽管理动态对象,那么请确保遵循规则三:你需要实现(或删除)复制构造函数和复制赋值运算符,以防止"浅"复制离开你两个试图删除相同对象的向量.您还需要注意删除删除或替换它们的任何其他位置的对象.存储智能指针(或者对象本身,如果你不需要多态性的指针)将为你处理所有这些事情,所以我总是建议这样做.

我知道我应该在循环之后清除向量,但这是我在尝试删除指针的每个常规方法之后所得到的.它似乎不喜欢删除命令.

最可能的原因是您没有遵循三规则,并且在复制矢量后意外地尝试删除两次相同的对象.它也可能GameState是一个基类,你忘了给它一个虚拟析构函数,或者指针已经被其他一些代码破坏了.