- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在争论一个似乎很奇怪的 realloc
与 valgrind 无法正常工作的情况。似乎我要么以某种方式分配了太多,要么错误地使用了 realloc
。我非常重视 valgrind 错误,这样的错误让我非常担心。
最小工作示例:
#include <stdlib.h>
typedef struct test {
size_t n;
size_t r;
int **ptrs;
} test;
test *new_test() {
test *t = malloc(sizeof(test));
t->n = 0; //number of elements
t->r = 1; //reserve
t->ptrs = calloc(t->r, sizeof(*(t->ptrs))); //calloc inits so we don't have to
return t;
}
void push_back_test(test *t, int *ptr) {
if (t->n == t->r) {
t->r <<= 1;
int **temp_ptr = realloc(t->ptrs, sizeof(t->ptrs) * t->r);
if (temp_ptr) {
t->ptrs = temp_ptr;
} else {
exit(EXIT_FAILURE);
}
//NULL out the rest
for (int **ptri = t->ptrs + t->n; ptri < t->ptrs + t->r; ++ptri) {
(*ptri) = NULL;
}
}
t->ptrs[t->n] = ptr;
++(t->n);
}
int main(int argc, char **argv) {
test *t = new_test();
int *a = calloc(2, sizeof(int)); //calloc inits
int *b = calloc(4, sizeof(int));
int *c = calloc(8, sizeof(int));
push_back_test(t, a);
push_back_test(t, b);
push_back_test(t, c);
push_back_test(t, a);
push_back_test(t, b);
exit(EXIT_SUCCESS);
}
Valgrind 输出:
==26528== Memcheck, a memory error detector
==26528== Copyright (C) 2002-2013, and GNU GPL'd, by Julian Seward et al.
==26528== Using Valgrind-3.10.1 and LibVEX; rerun with -h for copyright info
==26528== Command: ./test
==26528==
==26528== Conditional jump or move depends on uninitialised value(s)
==26528== at 0x435A32: __linkin_atfork (in /----/----/test)
==26528== by 0x414905: ptmalloc_init.part.8 (in /----/----/test)
==26528== by 0x414C7F: malloc_hook_ini (in /----/----/test)
==26528== by 0x465B1A: _dl_get_origin (in /----/----/test)
==26528== by 0x436AB4: _dl_non_dynamic_init (in /----/----/test)
==26528== by 0x437916: __libc_init_first (in /----/----/test)
==26528== by 0x40140F: (below main) (in /----/----/test)
==26528==
==26528== Conditional jump or move depends on uninitialised value(s)
==26528== at 0x4104BA: _int_free (in /----/----/test)
==26528== by 0x412C3B: _int_realloc (in /----/----/test)
==26528== by 0x414046: realloc (in /----/----/test)
==26528== by 0x40109D: push_back_test (test.c:20)
==26528== by 0x4011FB: main (test.c:44)
==26528==
==26528== Conditional jump or move depends on uninitialised value(s)
==26528== at 0x410518: _int_free (in /----/----/test)
==26528== by 0x412C3B: _int_realloc (in /----/----/test)
==26528== by 0x414046: realloc (in /----/----/test)
==26528== by 0x40109D: push_back_test (test.c:20)
==26528== by 0x4011FB: main (test.c:44)
==26528==
==26528==
==26528== HEAP SUMMARY:
==26528== in use at exit: 0 bytes in 0 blocks
==26528== total heap usage: 0 allocs, 0 frees, 0 bytes allocated
==26528==
==26528== All heap blocks were freed -- no leaks are possible
==26528==
==26528== For counts of detected and suppressed errors, rerun with: -v
==26528== Use --track-origins=yes to see where uninitialised values come from
==26528== ERROR SUMMARY: 3 errors from 3 contexts (suppressed: 0 from 0)
现在我知道第一个错误可能是我的 libc 的问题,但其余的基本上是在告诉我我没有清空我分配的所有内存并且正在传递垃圾,我相信我不会这样清空新分配的内容。
我已经尝试了很多变体,它们要么(正确地)崩溃要么给出这些消息。我很茫然。
编辑:我遇到问题的原始代码比这更正确。我现在已经修复了 MWE,仍然是一样的。
最佳答案
问题是 glibc 不是 Valgrind-clean。通常,这些错误似乎来自您的 libc.so.6
,Valgrind 对其进行了内置抑制。当您静态链接时,这些问题似乎源自您的二进制文件,因此不会被抑制。
您可以通过不静态链接或使用 suppressions 来解决此问题和 suppression files
如果您查看提示的内容,就会发现某些线程本地存储正在与 NULL 进行比较。如果附加调试器,结果会发现事情初始化得很好,问题是误报。
更多信息可以在 this SO thread 找到.
当然,多个评论指出了您使用 new_test
的原始错误和您传递给 realloc
的大小的现有错误。一旦这些问题得到修复,Valgrind 警告仍然存在,这就是原因。
关于c - 如何避免 realloc 上的 valgrind 警告?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35973187/
你好,我正在尝试在 opensuse 中创建一个 Shell 脚本来创建 MySqlUsers,但是当我尝试运行它时,我得到了这个错误: Warning: Could not start progra
我阅读了有关此错误的所有信息,但未能找到任何解决方案。 我有一个看起来像这样的简单页面: $xmlfile = "/var/www/marees.xml"; //Fichier dans lequel
运行 Websphere App 服务器 V8.5 Liberty Profile。我找不到任何可以解决这些警告的帮助。我在 eclipse 。 ************** He
我尝试在 GC AppEngine 上部署应用程序。部署过程中没有错误,但应用程序无法运行(仅显示加载页面)。日志中唯一一个奇怪的原始 OpenBLAS WARNING - could not det
我刚开始学习 RestKit。我正在尝试使用它来使用 Foursquare api 获取附近的 field 。但每次我尝试“objectLoader:(RKObjectLoader *)objectL
我对 Vuejs 比较陌生,每次按键时都会收到以下警告: [Vue warn]: $attrs is readonly. found in ---> at src\component
Warning: simplexml_load_file() [function.simplexml-load-file]: I/O warning : failed to load external
我在尝试修改某些表时不断收到此错误。这是我的代码: /** = 1){ //$this->mysqli->autocommit(FALSE); //insert th
当我尝试使用 PHP 的 ftp_put 函数上传文件时,早些时候出现错误: 警告:ftp_put() [function.ftp-put]:无数据连接 现在,我尝试开启被动模式: ftp_pasv(
我一直在努力让这段代码适用于现阶段的年龄。它旨在计算一个范围内的素数,我已经编写了一种方法来打印它们。不幸的是,代码将无法编译,引用警告: “警告:[未检查] 未检查调用 add(E) 作为原始类型
尝试使用带有架构组件和Kotlin的Android Studio 3 Canary 5构建示例会给出此警告。 谁能告诉我原因? 谢谢,Ove 编辑#1: 这是Dan Lew前段时间制作的样本 http
我正在编写一个 Shiny 的应用程序,它运行得非常好,突然我收到两条警告消息。我已经回到以前运行良好的副本,它们现在显示相同的错误消息,所以我真的很困惑。我的代码仍然运行并在我 Shiny 的仪表板
03-25 05:52:15.329 8029-8042/com.mgh.radio W/MediaPlayerNative: info/warning (703, 0) 03-25 05:52:15
我在构建时在我的 gradle 控制台中收到一条警告消息: 警告:[options] 引导类路径未与 -source 1.7 一起设置 1 条警告 我怎样才能解决这个问题? 任何帮助表示赞赏! 最佳答
我有下一个代码: 测试.c #include "a1.h" int main() { int a = 8; foo(a); return a; } a1.h void foo
我的程序中有一个 WORD 变量。 WORD hour; 但是当我比较它的时候 if(hour>=0 && hour=0 && hour=0 的比较,它始终适用于 hour 是 WORD 类型,它是一
安全研究人员警告称,一个最新的严重的Java错误,其本质与目前在全球范围内利用的臭名昭著的 Log4Shell 漏洞相同 。 CVE-2021-42392 尚未在国家漏洞数据库 (NVD) 中
安装SqlServer2005时“版本变更检查 (警告)"问题排查 今天同事在安装SqlServer2005时遇到“版本变更检查 (警告) ”问题导致安装失败,警告提示如下: - 版本
我的 UWP 项目中出现以下警告。我已经标记了解决方案的示例,但我更感兴趣的是为什么在同一平台上创建另一个空项目时不会出现此警告? APPX4001: Build property AppxBundl
我试图修复我的登录脚本,在我的本地主机上它可以工作,但上传到我的在线测试服务器时,注销被破坏,我得到这个错误: Warning: session_destroy() [function.session
我是一名优秀的程序员,十分优秀!