严重错误(一)

2023-12-13 12:27:29

这几天写代码的时候遇见一个严重的错误,导致我思考很久没有想到原因,一开始代码

class MyClass
{
private:
std::vector<int> s;
public:
void insert(int n);
MyClass() :s()
{

}
};
void MyClass::insert(int n)
{
s.push_back(n);
}
int main() {

复制
std::vector<MyClass*> test;
for (int i = 0; i < 3; i++)
{
    MyClass my;
    my.insert(i);
    test.push_back(&my);
}

return 0;
}

我本来想每次向test添加不同的元素,但是每次都没有成功,问题在于 my 对象是在每次迭代的循环体内创建的。这意味着在每次迭代结束时,my 对象会超出其作用域并被销毁。因此,当你在 test 向量中存储 my 对象的地址时,实际上是存储了一个已被销毁的对象的地址,这会导致未定义行为。为了解决这个问题,你可以使用动态内存分配来创建 MyClass 对象,并在使用完后手动释放该内存。以下是修改后的代码示例:

#include <vector>

class MyClass
{
private:
    std::vector<int> s;

public:
    void insert(int n);
};

void MyClass::insert(int n)
{
    s.push_back(n);
}

int main()
{
    std::vector<MyClass*> test;
    for (int i = 0; i < 3; i++)
    {
        MyClass* my = new MyClass();  // 使用动态内存分配创建 MyClass 对象
        my->insert(i);
        test.push_back(my);
    }

    // 使用完后释放动态分配的内存
    for (MyClass* my : test)
    {
        delete my;
    }

    return 0;
}

文章来源:https://blog.csdn.net/qq_39591612/article/details/134967605
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。