如何更正程序中检测到的***glibc错误

How to correct *** glibc detected *** error in the program

本文关键字:glibc 错误 检测 何更正 程序      更新时间:2023-10-16

可能重复:
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标志编译程序,并通过调试器或内存调试器运行。这将显示错误的确切发生位置。

看起来您正在尝试freeinvalid 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标志重新编译代码。

或者,你可以在这里发布你的代码,让社区看看你哪里出了问题。