【发布时间】:2019-04-16 16:47:59
【问题描述】:
我有一个类,用于表示具有未指定维数的向量 VectorN:
int Size = 0;
VectorN::VectorN(int L)
{
Size = L;
Dimentions = new double[L];
}
VectorN::~VectorN()
{
delete[] Dimentions;
}
VectorN VectorN::operator+(const VectorN &rhs)
{
VectorN r = VectorN(this->Size);
for (int i = 0; i < Size; i++)
{
r[i] = Dimentions[i] + rhs.Dimentions[i];
}
return r;
}
double& VectorN::operator[](int arg)
{
return Dimentions[arg];
}
这在我的主要功能中使用:
VectorN test = VectorN(1);
test[0] = 1;
VectorN test2 = VectorN(1);
test2[0] = 1;
VectorN test3 = VectorN(1);
test3 = test + test2;
但是,在最后一行之后,程序会遇到“断点”,并显示消息“指定给 RtlValidateHeap 的地址无效”
我认为正在发生的是这条线
test3 = test + test2;
通过创建 VectorN 的临时实例导致问题
test + test2
然后将其复制到 test3 中,然后删除临时版本,因为它超出了 add 函数的范围,但是由于它仍在 test3 中被引用,编译器出现问题,因为它试图删除一个仍在存在的变量跟踪。 (请谨慎对待,我不是 C++ 专家,所以这可能是完全错误的。)
我想我可以通过简单地传递一个指向在重载加法函数中创建的对象的指针来解决这个问题,但是我宁愿不冒内存泄漏的风险,因为每次我对类使用加法时都必须手动删除创建的实例。
【问题讨论】:
-
如果您将
std::unique_ptr<double[]>或std::vector<double>用于Dimensions而不是原始指针,则会为自己省去很多麻烦。
标签: c++