我认为我有内存泄漏.现在什么

I *think* I have a memory leak. What now?

本文关键字:在什么 泄漏 内存      更新时间:2023-10-16

我创建了一个c++ DLL函数,它使用几个数组来处理最终的图像数据。我试图通过引用传递这些数组,进行计算,并在预分配的数组中通过引用传递输出。在函数中,我使用英特尔性能原语,包括ippsMalloc和ippsFree:

Process.dll
int __stdcall ProcessImage(const float *Ref, const float *Source, float *Dest, const float *x, const float *xi, const int row, const int col, const int DFTlen, const int IMGlen)
{
int k, l;
IppStatus status;
IppsDFTSpec_R_32f *spec;
Ipp32f *y = ippsMalloc_32f(row),
    *yi = ippsMalloc_32f(DFTlen),
    *X = ippsMalloc_32f(DFTlen),
    *R = ippsMalloc_32f(DFTlen);
for (int i = 0; i < col; i++)
{
    for (int j = 0; j < row; j++)
        y[j] = Source[j + (row * i)];
    status = ippsSub_32f_I(Ref, y, row);
            // Some interpolation calculations calculations here
    status = ippsDFTInitAlloc_R_32f(&spec, DFTlen, IPP_FFT_DIV_INV_BY_N, ippAlgHintNone);
    status = ippsDFTFwd_RToCCS_32f(yi, X, spec, NULL);
    status = ippsMagnitude_32fc( (Ipp32fc*)X, R, DFTlen);
    for (int m = 0; m < IMGlen; m++)
        Dest[m + (IMGlen * i)] = 10 * log10(R[m]);
}
_CrtDumpMemoryLeaks();
ippsDFTFree_R_32f(spec);
ippsFree(y);
ippsFree(yi);
ippsFree(X);
ippsFree(R);
return(status);
}

函数调用是这样的:

for (int i = 0; i < Frames; i++)
    ProcessFrame(&ref[i * FrameSize], &source[i * FrameSize], &dest[i * FrameSize], mX, mXi, NumPixels, Alines, DFTLength, IMGLength);

该函数不会失败,并为多达6张图像产生所需的输出,超过6张图像,它将终止:

First-chance exception at 0x022930e0 in DLL_test.exe: 0xC0000005: Access violation reading location 0x1cdda000.

我试图调试程序,不幸的是VS报告调用堆栈位置是在一个IPP DLL与"无源可用"。调用ippMagnitude32fc( (Ipp32fc*)X, R, DFTlen)

时总是失败

这导致我的问题:这是内存泄漏吗?如果是这样,有人能看到泄漏的位置吗?如果没有,有人能建议如何去调试这个问题吗?

回答你的第一个问题,不,这不是内存泄漏,这是内存损坏。内存泄漏是当您没有释放所使用的内存时发生的,因此,内存使用量正在增长。这不会使程序不工作,但最终只会使用太多的内存,这导致计算机非常慢(交换),最终任何程序崩溃与"内存不足的错误"。你得到的是基本的指针错误,这在c++中经常发生。解释如何调试是困难的,我建议您在崩溃之前添加一个断点,并尝试查看出错的地方。