奇怪的回溯 - 错误在哪里?

时间:2009-08-05 05:58:38

标签: c++ gdb backtrace

我正在用C ++开发一个图像处理应用程序。我已经看到很多编译器错误和回溯,但这个对我来说是新的。

#0  0xb80c5430 in __kernel_vsyscall ()
#1  0xb7d1b6d0 in raise () from /lib/tls/i686/cmov/libc.so.6
#2  0xb7d1d098 in abort () from /lib/tls/i686/cmov/libc.so.6
#3  0xb7d5924d in ?? () from /lib/tls/i686/cmov/libc.so.6
#4  0xb7d62276 in ?? () from /lib/tls/i686/cmov/libc.so.6
#5  0xb7d639c5 in malloc () from /lib/tls/i686/cmov/libc.so.6
#6  0xb7f42f47 in operator new () from /usr/lib/libstdc++.so.6
#7  0x0805bd20 in Image<Color>::fft (this=0xb467640) at ../image_processing/image.cpp:545

这里发生了什么?操作员new崩溃了,好的。但为什么?这不是内存不足(它试图分配大约128Kb,128x64像素,每个都有两个浮点数)。此外,它不会接缝,因为它是我自己的代码中的错误(构造函数不会被触及!)。

上述行(#7)中的代码是:

Image<Complex> *result = new Image<Complex>(this->resX, resY); 
// this->resX = 128, resY = 64 (both int), Complex is a typedef for std::complex<float>

几乎相同的实例化工作在我的代码中的其他地方。如果我注释掉这部分代码,稍后会在类似的部分崩溃。我不明白,我也没有任何想法,如何调试它。有什么帮助吗?

编译器是gcc 4.3.3,libc是2.9(都来自Ubuntu Jaunty)

更新

我在同一方法和main()

中的错误行上方包含了以下行
    Image<Complex> *test = new Image<Complex>(128, 64);
    delete test;

奇怪的是:在同一个方法中它会崩溃,在main()中它不会崩溃。正如我所提到的,Complex是std :: complex&lt; float&gt;的typedef。构造函数没有被调用,我在这行之前和构造函数本身插入了一个cout。

更新2:

感谢KPexEA提供此技巧!我试过这个:

Image<Complex> *test = new Image<Complex>(128, 64);
delete test;

kiss_fft_cpx *output = (kiss_fft_cpx*) malloc( this->resX * this->resY/2 * sizeof(kiss_fft_cpx) );
kiss_fftndr( cfg, input, output );

Image<Complex> *test2 = new Image<Complex>(128, 64);
delete test2;

它崩溃了 - 你猜? - test2!所以我的Kissfft接缝的malloc是错误的。我会看看它。

最终更新:

好的,已经完成了!感谢大家!

实际上,我之前应该注意到它。上周,我注意到,Kissfft(快速傅立叶变换库)从128x128像素源图像制作了130x64像素的fft图像。是的,130像素宽,不是128.不要问我为什么,我不知道!因此,必须分配130x64x2xsizeof(float)字节,而不是之前的128x64x ......奇怪的是,它在我修复了这个bug后没有崩溃,但是几天之后。

为了记录,我的最终代码是:

int resY = (int) ceil(this->resY/2);

kiss_fft_cpx *output = (kiss_fft_cpx*) malloc( (this->resX+2) * resY * sizeof(kiss_fft_cpx) );
kiss_fftndr( cfg, input, output );

Image<Complex> *result = new Image<Complex>(this->resX, resY);

谢谢!

craesh

2 个答案:

答案 0 :(得分:5)

也许先前分配的内存块有缓冲区溢出会破坏堆?

答案 1 :(得分:0)

您没有分配足够的内存。 kissfft的半光谱格式(以及FFTW和IMKL)包含X *(Y / 2 + 1)复杂元素。

请参阅kiss_fftndr.h头文件:

/ *  输入timedata有dims [0] X dims [1] X ... X dims [ndims-1]标量点

输出freqdata有dims [0] X dims [1] X ... X dims [ndims-1] / 2 + 1复杂点 *