- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我写了这个malloc
的小版本(没有 free
):
#include <cstdio>
#include <cstddef>
#include <unistd.h>
#define word_size sizeof(intptr_t)
#define align(n) ((n + word_size - 1) & ~(word_size - 1))
void* my_malloc(size_t size) {
void* p = sbrk(0);
printf("before allocation: %p\n", p);
if (sbrk(align(size)) == (void*) -1) {
// failed to allocate memory
return NULL;
}
printf("after allocation: %p\n", sbrk(0));
return p;
}
int main() {
int* foo = (int*) my_malloc(1);
*foo = 100;
printf("after allocation outside: %p\n", sbrk(0));
}
before allocation: 0x1796000
after allocation: 0x1796008
after allocation outside: 0x1796008
my_malloc
分配的内存没有被释放。
valgrind
有了这个:
valgrind --leak-check=yes ./main
==1592== Memcheck, a memory error detector
==1592== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
==1592== Using Valgrind-3.13.0 and LibVEX; rerun with -h for copyright info
==1592== Command: ./main
==1592== HEAP SUMMARY:
==1592== in use at exit: 0 bytes in 0 blocks
==1592== total heap usage: 2 allocs, 2 frees, 73,728 bytes allocated
==1592==
==1592== All heap blocks were freed -- no leaks are possible
==1592==
==1592== For counts of detected and suppressed errors, rerun with: -v
==1592== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
valgrind
没有发现任何内存泄漏!我在用
valgrind
不正确,还是这是一个错误?
最佳答案
第一个答案不是很准确。
OP 的简短回答:除非您告诉它更多有关分配器的信息,否则 Valgrind 不会检测到自定义内存池中的泄漏。
长答案。
当您运行 valgrind
时,将运行两个可执行文件。首先是 valgrind
本身。这是一个小型应用程序,它将读取一些命令行参数,设置一些环境变量,然后查看 guest 应用程序以确定其位数,然后 execve
是适当的工具,例如 memcheck-x86-freebsd
。
该工具不与 任何 链接。不是 libc,甚至不是 libc 启动代码。入口点位于创建新堆栈并从 valgrind_main
开始的汇编器中。由于该工具没有任何链接,它必须为自己实现它需要或想要使用的所有 C 运行时函数。这包括编译器可能隐式生成的一些函数。例如,执行结构体赋值的代码可能会导致编译器生成对 memcpy()
的调用。这就是引用的文本所指的内容。这些功能也由工具提供,而不是由 libc 提供。这与重定向机制无关。
所以,重定向。 valgrind
将设置 LD_PRELOAD
(或特定于平台的版本,例如 LD_32_PRELOAD
)。这将指向一个“核心”组件(例如 vgpreload_core-x86-freebsd.so
和一个工具组件,例如 vgpreload_memcheck-x86-freebsd.so
。该工具执行链接加载器的工作,并将 mmap
这些文件放入内存中。在此过程中,它将读取 Elf
信息并注意任何“特殊”功能。这些功能使用精心设计的名称修改系统,并且该工具将识别出,例如, _vgr10010ZU_libcZdsoZa_malloc
是 malloc
中 libc
的替代品。这些重定向功能的地址被存储,并将在 guest 执行时使用. 这种机制也意味着不同的工具可以重定向不同的函数。例如,memcheck
需要重定向 malloc
和 new
函数族,而 DRD
和 Helgrind
需要重定向 0x1045 和 67x1045。
对于重定向的另一端,该工具在加载 libc 时还会看到目标函数(以及可执行二进制文件本身,它涵盖了
静态链接的情况)。
重定向并没有完全取代目标函数,它只是充当一个垫片,允许工具跟踪函数所请求的内容。
现在回到 pthread_*
。 Valgrind 确实知道这一点,但只是作为系统调用。它将检查 sema_*
参数是否来自无效存储。 sbrk
不会像 size
那样跟踪内存。如果您将 memcheck
与 malloc
一起使用,那么它将分析 massif
的使用情况。
如果您希望 --pages-as-heap=yes
验证您的自定义分配函数,那么您必须执行以下两项操作之一。
sbrk
参数 关于c - sbrk - Valgrind 不报告内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62094226/
#include #include void *my_malloc(size_t size){ void *p; void *q; p = sbrk(0); /* If sbrk fails,
我的分配代码是 dat* data = NULL; data = sbrk(SIZE); if((int) data != -1){ return data }else{ printf("N
我想知道是否有人已经看到 sbrk(0) 失败? 我的意思是,如果你能达到这个功能,你显然之前就有访问内存的权限,所以检查当前的中断位置应该没问题,对吧? 编辑:例如,我应该考虑错误异常吗? 最佳答案
当 sbrk() 返回指向堆起始地址的指针时,地址是升序还是降序?例如,如果我有一个从地址 1 到 10 的 10 字节堆,sbrk() 会返回指向地址 10 或 1 的指针吗? 类似地,堆地址往往会
我在使用 sbrk 释放内存时遇到了问题。我向 sbrk 传递了一个负值,但它不会减少堆的开始。这是代码 int main(int argc, char** argv) { void * a
我正在尝试了解 sbrk 的工作原理。 这是我的小代码: int main() { printf("end of the break : %p\n", sbrk(0)); prin
因此,作为挑战和性能,我正在用汇编语言编写一个简单的服务器。我知道的唯一方法是通过系统调用。 (通过 int 0x80)显然,我将需要比在汇编或加载时分配的内存更多的内存,所以我阅读并决定我想使用 s
在32位Linux系统上,一个进程最多可以访问4GB的虚拟地址空间;然而,在保留其中任何一项方面,进程似乎在不同程度上是保守的。因此,使用 malloc 的程序偶尔会通过系统调用 sbrk/brk 增
我写了这个malloc的小版本(没有 free): #include #include #include #define word_size sizeof(intptr_t) #define a
我正在尝试在我的 mac(运行 Sierra)上构建一个大型 binutils 文件,每次尝试构建时,都会出现错误,提示“sbrk 已弃用”。我尝试在 Makefile 中的 CFLAGS 中添加“-
好的,所以我有一个看起来像的结构 typedef struct meta { size_t size; struct meta* next; struct meta* prev
我有一个游戏引擎,我想快速查看它使用了多少堆,所以我实现了这两个小例程 static void * start_memory = 0; unsigned long System::memoryUsag
我想知道是否有比malloc/free低一级的跨平台分配器。 例如,我想要一些在 Linux 中简单地调用 sbrk 并在 Windows 中调用 VirtualAlloc 的东西(可能还有两个类似的
以下是一个简单的 malloc 实现的代码。链表由用于内存管理的头指针和尾指针启动。现在在函数中,只有一个调用在列表未初始化时实现,即列表的头部被初始化。一旦我将底层指针返回到 main,程序就会给出
我的程序很简单, ... #define TO_INT(a) (*(int *)a) void *pool_head; void *pool_tail; ... pool_head = sbrk(BU
我尝试写一个非常简单的操作系统来更好地理解基本原理。我需要实现用户空间 malloc。所以一开始我想在我的 linux 机器上实现和测试它。 起初我通过以下方式实现了sbrk()函数 void* sb
我正在尝试创建我自己的 malloc 函数,但我还没有完成。这是我的代码的相关部分: mymalloc.h : #pragma once #include typedef struct METADA
我正在尝试使用 sbrk 系统调用请求一个内存页并将该页分成小块,但我的代码总是遇到一些无效内存: void sbrkBlocks() { int *b = sbrk(0); if(s
我想弄清楚可以使用 malloc() 为进程分配多少内存。 所以要点是: start = sbrk(0); malloc(1); /* so space is given to the data se
我有一个自定义分配器函数,它使用 sbrk() 来获取内存。当不再需要它时,如何释放它? 对于 malloc() 是否有等同于 free() 的函数? 还是我必须使用 brk() 来设置数据段的结尾?
我是一名优秀的程序员,十分优秀!