Valgrind报告写入错误?为什么?
Valgrind report write error? why?
运行Valgrind的memcheck时,偶尔Valgrind会报告如下错误:
===2745===Memcheck,内存错误检测器===2745===版权所有(C)2002-2010和GNU GPL,由Julian Seward等人。===2745===使用Valgrind-3.6.0和LibVEX;使用-h重新运行以获取版权信息===2745===命令:/HSFramework===2745======2745===大小为8的无效写入===2745===在0x3B81C097C0:do_lookup_x(在/lib64/ld-2.112.so中)===2745===由0x1C31032D:???===2745===由0x3B81C09E19:_dl_lookup_symbol_x(在/lib64/ld-2.112.so中)===2745===地址0x7feffee78在线程1的堆栈上===2745===平台:Linux 2.6.32-220.el6.x86_64 x86_64 x86_64 x8_64 GNU/Linux
从这个错误报告中没有关于我的代码的线索。我对这份错误报告一无所知
什么原因会导致此错误?
这个错误意味着你在do_lookup_x中得到了缓冲区溢出,如果你让它的源代码查看或与我们共享。
http://valgrind.org/docs/manual/quick-start.html
这意味着do_lookup_x
函数执行了无效的写入访问。该函数是运行库的一部分(不太可能是问题的根源)。我会联系HSFramework的作者,看看他们是否可以像运行一样通过运行valgrind来解决这个问题
相关文章:
- 我的字符计数代码计算错误.为什么
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- xmake总是报告:错误:无法获取cxx的程序,为什么
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 为什么加载SDF会导致Mobilizer创建闭环错误
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 为什么包含windows.h会产生语法错误,从而阻止类的实例化?(C2146,C2065)
- 为什么我在使用void函数时得到错误代码C2276
- 为什么类中的ostringstream类型的成员会导致";调用隐含删除复制构造函数";错误
- 为什么g++在未执行的代码处标记强制转换错误
- 有人知道为什么在开关中使用stoi函数会返回恒定的错误吗
- 为什么创建友元类的实例会导致"undefined reference to"错误?
- 为什么错误"permission denied","id returned 1 exit status"仅在 IM 使用 C++ 中的头文件 fstream 时才出现
- 为什么错误:"locate_zone"不是"std::chrono"的成员
- 为什么错误 C6386 缓冲区溢出与 strsafe.h 字符串 Cch 函数
- 为什么错误1400无效的窗口句柄
- 为什么错误LNK2001:在这种情况下未解析的外部符号
- c++为什么错误:no match for 'operator='
- 为什么错误"invalid conversion from 'char' to 'const char*"?