瓦尔格林德'uninitialised value'依赖项不引用我的代码
Valgrind 'uninitialised value' dependency doesn't reference my code
这个valgrind输出让我感到困惑,因为它似乎没有引用我的代码,并且我已经在使用STL编写的多个程序中得到了它,尽管没有HEAP SUMMARY错误:
$ valgrind -v --leak-check=full --track-origins=yes ./hellostl
...
==7989== Conditional jump or move depends on uninitialised value(s)
==7989== at 0x4017AA6: index (in /lib64/ld-2.17.so)
==7989== by 0x4007A12: expand_dynamic_string_token (in /lib64/ld-2.17.so)
==7989== by 0x4008304: _dl_map_object (in /lib64/ld-2.17.so)
==7989== by 0x400181D: map_doit (in /lib64/ld-2.17.so)
==7989== by 0x400E985: _dl_catch_error (in /lib64/ld-2.17.so)
==7989== by 0x40010EF: do_preload (in /lib64/ld-2.17.so)
==7989== by 0x40039D7: dl_main (in /lib64/ld-2.17.so)
==7989== by 0x40152B7: _dl_sysdep_start (in /lib64/ld-2.17.so)
==7989== by 0x4004E94: _dl_start (in /lib64/ld-2.17.so)
==7989== by 0x4001637: ??? (in /lib64/ld-2.17.so)
==7989== Uninitialised value was created by a stack allocation
==7989== at 0x4003961: dl_main (in /lib64/ld-2.17.so)
==7989==
==7989== Conditional jump or move depends on uninitialised value(s)
==7989== at 0x4017AAB: index (in /lib64/ld-2.17.so)
==7989== by 0x4007A12: expand_dynamic_string_token (in /lib64/ld-2.17.so)
==7989== by 0x4008304: _dl_map_object (in /lib64/ld-2.17.so)
==7989== by 0x400181D: map_doit (in /lib64/ld-2.17.so)
==7989== by 0x400E985: _dl_catch_error (in /lib64/ld-2.17.so)
==7989== by 0x40010EF: do_preload (in /lib64/ld-2.17.so)
==7989== by 0x40039D7: dl_main (in /lib64/ld-2.17.so)
==7989== by 0x40152B7: _dl_sysdep_start (in /lib64/ld-2.17.so)
==7989== by 0x4004E94: _dl_start (in /lib64/ld-2.17.so)
==7989== by 0x4001637: ??? (in /lib64/ld-2.17.so)
==7989== Uninitialised value was created by a stack allocation
==7989== at 0x4003961: dl_main (in /lib64/ld-2.17.so)
是否有可能我正在使用过时的版本的东西(例如编译器,valgrind…)?
编辑:触发bug的简单代码:
#include <vector>
#include <iostream>
using namespace std;
int main ()
{
vector<int> foo;
for (int i = 0; i < 50; ++i)
foo.push_back( i );
for (auto it = foo.begin();
it != foo.end();
++it)
{
cout << *it << endl;
}
}
动态链接库因导致Valgrind警告而臭名昭著。你观察到的这个其实是很常见的。您无法修复此警告,但如果它惹恼了您,您可以添加抑制规则。
更详细地说,这里发生的事情是在程序运行之前,c++标准库被动态链接。如果用ldd
检查二进制文件,您应该看到这样一行:
libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007fa0e2f72000)
如果你静态链接这个库,你的程序将在没有动态链接的情况下运行,并且警告将消失。
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 我的字符计数代码计算错误.为什么
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么我的代码在输出中增加了93天
- 我的简单if-else语句是如何无法访问的代码
- 0-1背包代码中的错误.我的代码中有什么错误
- 我的代码中有错误吗?使用BGI图形的C++代码对我不起作用
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 尝试链接我的着色器时,我收到错误代码"error c5145 must write to gl_position"
- 在我的代码中,获得最大的Pair Wise产品C++和输出并不总是正确的
- 代码在我的计算机上运行良好,但是在将其提交给coursera时遇到未知的信号11问题
- 为什么我需要C++中不同的排序格式来对这个USACO代码上的数组和优先级队列进行排序
- 为什么我的C++代码中出现'Segmentation Fault: 11'行?
- 是否值得降低我的代码的可读性,以便在出现内存不足错误时提供异常安全性?
- 为什么我的C++程序的程序集输出充满了 .ascii,没有汇编代码?
- 无法在我的堆排序代码中找到错误.无法正确执行.C++
- 如何重写全局方法名称以在调用原始方法之前将我的代码推到前面
- 为什么我的 BaseClass:Method 代码编译(带有单冒号)?
- 我的代码运行良好,但在游戏循环中中断
- 8谜题代码.我的队列没有填充,我找不到错误的位置