1

我正在通过 Learn C the Hard Way 进行学习,我正在开始关于 valgrind 的部分

示例输出的摘录如下:

==3082== Use of uninitialised value of size 8 
==3082==    at 0x4E730EB: _itoa_word (_itoa.c:195) 
==3082==    by 0x4E743D8: vfprintf (vfprintf.c:1613) 
==3082==    by 0x4E7E6F9: printf (printf.c:35) 
==3082==    by 0x40052B: main (ex4.c:11) 

虽然我的输出如下所示:

==2362== Use of uninitialised value of size 4 
==2362==    at 0x40885CB: _itoa_word (in /lib/libc-2.16.so)
==2362==    by 0x408C13E: vfprintf (in /lib/libc-2.16.so)
==2362==    by 0x4092AE: printf (in /lib/libc-2.16.so)
==2362==    by 0x4061604: (below main) (in /lib/libc-2.16.so) 

如何让我的 Valgrind 输出匹配?我并不十分担心第 2-4 行,但我更希望最后一行实际上是对应的(而且我猜它可能还是相关的)。


我像这样构建了我的 ex4:

$ make ex4
cc -Wall -g    ex4.c    -o ex4
** Some warnings here **

然后像这样执行valgrind:

$ valgrind ./ex4

我正在运行从 Arch linux、GCC 4.7.1 上的源代码构建的 valgrind 3.7.0,并且因为我有 GLIBC 1.6,所以我修改了我的配置文件并添加了以下代码:

     2.16)
        { $as_echo "$as_me:${as_lineno-$LINENO}: result: 2.16 family" >&5
$as_echo "2.16 family" >&6; }

$as_echo "#define GLIBC_2_16 1" >>confdefs.h

DEFAULT_SUPP="glibc-2.X.supp ${DEFAULT_SUPP}"
DEFAULT_SUPP="glibc-2.34567-NPTL-helgrind.supp ${DEFAULT_SUPP}"
DEFAULT_SUPP="glibc-2.X-drd.supp ${DEFAULT_SUPP}"
;;

就在与前一个案例;;相匹配的下方。2.14)

4

1 回答 1

1

我怀疑您没有安装标准库的调试/符号。

由于库版本不同,输出总是会略有不同,但您应该能够通过调试包获得一些行号。

您可能需要-O0避免被main()忽略。

于 2012-12-18T10:00:06.687 回答