gpt4 book ai didi

c++ - 堆——构造函数和析构函数,内存分配

转载 作者:行者123 更新时间:2023-11-30 02:36:07 29 4
gpt4 key购买 nike

我有一个带有构造函数和析构函数以及另一种方法的类。当我创建此类的新实例时,它会在某处调用析构函数,我不知道为什么。

class Heap
{
private:
int *heap;
int size;
int heap_size;
public:
Heap(int new_size)
{
size = new_size;
heap_size = 0;
heap = (int*)malloc(new_size*sizeof(int)); //???
//heap = new int[new_size]; //???
}
~Heap()
{
free(heap);
}
void add(int alfa)
{
// something
}
};

int _tmain(int argc, _TCHAR* argv[])
{
srand(time(NULL));
int k = rand() % 100 + 1;
Heap *name = &Heap(k);
Heap *name2 = new Heap(k); //what's the diffrence?
while (k > 0)
{
name->add(rand()); // doesn't work, because destructor is called before
k--;
}
system("pause");
return 0;
}

最佳答案

在运行这段非标准代码的过程中1,这很可能会产生未定义的行为2无论如何,这一行

Heap *name = &Heap(k);

产生一个临时的 Heap 对象,该对象在完整表达式的末尾被销毁。这导致析构函数被调用。

请注意,事实仍然是您的类非常脆弱,因为它不遵循 the rule of three (five) .复制 Heap 对象会导致双重删除。


1 出于充分的理由,标准 C++ 不允许获取临时地址。
2 这个结构给你留下了一个悬空指针。从技术上讲,取消引用 name 会导致未定义的行为。

关于c++ - 堆——构造函数和析构函数,内存分配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33102364/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com