我有一个方法,该方法会生成一个巨大的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();
}
}
Data :: 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));
}
可能是什么?内存泄漏(由于先前的调用没有释放内存,不可能再次分配这么大的连续内存吗?)? ...我只是不明白问题出在什么地方,在离开方法范围之前,我什至手动清理了数组并释放了内存...我将不胜感激
答案 0 :(得分:0)
通过将mingw32更改为mingw64解决了问题