我有一个方法,它生成一个巨大的QVector<uchar>
(大小:354792000(,内存是动态分配/释放的,为了方便起见,我使用QScopedPointer:
void someMethod(int SIZE) {
chVec.reset(new QVector<uchar>(SIZE));
/*doing some stuff with an array...*/
chVec.data()->clear();
chVec.data()->squeeze();
}
创建小尺寸的数组-没问题,你也可以创建一个大尺寸的数组,但当我再次调用该方法时,我会得到错误"传递给C运行时函数的无效参数"。它通过了调试器,在尝试为新数组分配空间时发生错误:
template <typename T>
QVector<T>::QVector(int asize, const T &t)
{
Q_ASSERT_X(asize >= 0, "QVector::QVector", "Size must be greater than or equal to 0.");
if (asize > 0) {
d = Data::allocate(asize);
Q_CHECK_PTR(d); /*<------ Error occured*/
d->size = asize;
T* i = d->end();
while (i != d->begin())
new (--i) T(t);
} else {
d = Data::sharedNull();
}
}
数据::allocate(asize(;:
Q_REQUIRED_RESULT static QTypedArrayData *allocate(size_t capacity,
AllocationOptions options = Default)
{
Q_STATIC_ASSERT(sizeof(QTypedArrayData) == sizeof(QArrayData));
return static_cast<QTypedArrayData *>(QArrayData::allocate(sizeof(T),
Q_ALIGNOF(AlignmentDummy), capacity, options));
}
可能是什么?内存泄漏(不可能再次分配如此大的连续内存块,因为上一次调用没有释放内存?(。。。我只是不明白问题出在哪里,在离开方法范围之前,我甚至手动清理数组并释放内存。。。我将感谢的任何建议
通过将mingw32更改为mingw64 解决了问题