我目前面临一个非常奇怪的问题。我正在构建一个库并将其链接到我的程序。一切运行良好,没有分段错误(也使用 gdb 检查)但是当我使用 Valgrind 运行程序时,它会因为以下行而疯狂:
==11972== Invalid read of size 8
==11972== at 0x509509C: setcontext (setcontext.S:73)
==11972== by 0x509764F: ??? (in /lib/x86_64-linux-gnu/libc-2.15.so)
==11972== Address 0x541f060 is 128 bytes inside a block of size 936 alloc'd
==11972== at 0x4C2B3F8: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==11972== by 0x402090: environment_get (env.c:99)
==11972== by 0x401ED6: environment_new (env.c:36)
==11972== by 0x40124B: thr_new (thr.c:156)
==11972== by 0x400EBE: main (itest1.c:31)
但是程序运行良好,并且setcontext
有一个正确分配的参数,没有问题。我有什么理由担心这些台词吗?
谢谢