严重错误(一)
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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!