可能重复:
glibc检测到错误
嗨,当我按下switch案例中的一个选项时,我收到这个错误时,我正在GNUC++中执行我的项目。由于程序的其余部分执行得很好,我只剩下这个错误。我不知道它是什么,也不知道为什么会发生。请解释并指导我在我的程序中可以从哪里开始查找。
错误详细信息:
*** glibc detected *** ./test.out: free(): invalid pointer: 0xbfb1c874 ***
======= Backtrace: =========
/lib/libc.so.6[0x55c0f1]
/lib/libc.so.6(cfree+0x90)[0x55fbc0]
./test.out[0x809f855]
./test.out[0x804fbc0]
./test.out[0x804f9bb]
./test.out[0x80502bb]
./test.out[0x805084e]
./test.out[0x8050d07]
/lib/libc.so.6(__libc_start_main+0xdc)[0x508e8c]
./test.out[0x8049981]
======= Memory map: ========
004f3000-00631000 r-xp 00000000 08:01 6148422 /lib/libc-2.5.so
00631000-00633000 r-xp 0013e000 08:01 6148422 /lib/libc-2.5.so
00633000-00634000 rwxp 00140000 08:01 6148422 /lib/libc-2.5.so
00634000-00637000 rwxp 00634000 00:00 0
0078d000-007a7000 r-xp 00000000 08:01 6152013 /lib/ld-2.5.so
007a7000-007a8000 r-xp 00019000 08:01 6152013 /lib/ld-2.5.so
007a8000-007a9000 rwxp 0001a000 08:01 6152013 /lib/ld-2.5.so
007f9000-0081e000 r-xp 00000000 08:01 6148435 /lib/libm-2.5.so
0081e000-0081f000 r-xp 00024000 08:01 6148435 /lib/libm-2.5.so
0081f000-00820000 rwxp 00025000 08:01 6148435 /lib/libm-2.5.so
00b18000-00b23000 r-xp 00000000 08:01 6148439 /lib/libgcc_s-4.1.2-20080825.so.1
00b23000-00b24000 rwxp 0000a000 08:01 6148439 /lib/libgcc_s-4.1.2-20080825.so.1
08048000-080c6000 r-xp 00000000 00:1e 736543 /users/guest10/shashi/Demo/src/test.out
080c6000-080c7000 rwxp 0007e000 00:1e 736543 /users/guest10/shashi/Demo/src/test.out
080c7000-080cc000 rwxp 080c7000 00:00 0
08d05000-218b1000 rwxp 08d05000 00:00 0 [heap]
b7e00000-b7e21000 rwxp b7e00000 00:00 0
b7e21000-b7f00000 ---p b7e21000 00:00 0
b7fab000-b7fac000 rwxp b7fab000 00:00 0
b7fc4000-b7fc7000 rwxp b7fc4000 00:00 0
b7fc7000-b7fc8000 r-xp b7fc7000 00:00 0 [vdso]
bfb0b000-bfb21000 rw-p bffe9000 00:00 0 [stack]
Abort
请帮忙。。感谢Adv
只有向我们展示代码,才能提供确切的解决方案。然而,错误是显而易见的。该代码释放无效或不再有效的内存。这意味着地址要么是错误的,因为例如指针运算是在原始指针上进行的。或者指针已被释放(两次释放)。
您很可能正在尝试free
一个未动态分配的内存。也许你有一个不必要的free
或一个打字错误,比如:free(&buf)
而不是free(buf)
。
使用-g
标志编译程序,并通过调试器或内存调试器运行。这将显示错误的确切发生位置。
看起来您正在尝试free
和invalid pointer
。您可以使用类似[Valgrind][1]
的内存检查程序运行该程序,如下所示:
valgrind --tool=memcheck --leak-check=full --track-origins=yes --show-reachable=yes --log-file=val.log ./<executable> <parameters>
看看val.log
,您应该能够弄清楚内存泄漏发生在哪里。此外,您可以尝试使用gdb/ddd (debuggers)
逐步完成代码。程序将在出现segmentation fault
的位置失败。要使代码成为debuggable
,您需要使用-g
标志重新编译代码。
或者,你可以在这里发布你的代码,让社区看看你哪里出了问题。