1

当我尝试下面的代码时,我无法清楚地分析 malloc api 内部调用。我不清楚的是系统调用 mmap 只为 2 个或多个 malloc 调用调用一次。如果我分配的字节数也超过 4069在内部仅调用一个 mmap(使用 strace -p processid 标识跟踪)。

#include<stdio.h>
#include<stdlib.h>

main()
{
int *p,*q;
sleep(20);
p=malloc(5096);
printf("p=%p\n",p);
q=malloc(4096);
printf("q=%p\n",q);
sleep(2);
return 0;
}

strace 输出:

root@TEST:/home/harish# strace  -p 6109
Process 6109 attached
restart_syscall(<... resuming interrupted call ...>
) = 0
brk(0)                                  = 0xeca000
brk(0xeec000)                           = 0xeec000
fstat(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 14), ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f10b7bc7000
write(1, "p=0xeca010\n", 11)            = 11
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigaction(SIGCHLD, NULL, {SIG_DFL, [], 0}, 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
nanosleep({20, 0},
0x7ffc34a51790)      = 0
write(1, "q=0xecb020\n", 11)            = 11
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigaction(SIGCHLD, NULL, {SIG_DFL, [], 0}, 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
nanosleep({2, 0}, 0x7ffc34a51790)       = 0
exit_group(0)                           = ?
+++ exited with 0 +++

我正在寻找的是,如果 malloc 使用得更多,那么它会调用一个以上的 mmap,因为内存超过了两个 malloc 超过 4096

4

2 回答 2

2

malloc()不会导致mmap()调用。通常它会导致brk(). 但是,并非每次调用都会导致brk(). 这在很大程度上取决于当前分配的页面、请求的内存和其他东西。

于 2016-06-15T08:45:44.457 回答
2

您的进程的内部堆(通过 malloc、free 和 realloc 访问)管理它认为合适的内存 - 这包括:

  • 以大的或固定的增量增长堆,以分摊昂贵brk/sbrk系统调用的成本在多个(取消)分配上
  • 处理该堆区域本身内的较小(取消)分配
  • 管理分配记录的(去)碎片化

对大小分配使用不同的机制也很常见,例如从brk/管理的连续区域分配小对象sbrk,但可以直接使用 分配单个大对象mmap

于 2016-06-15T09:17:59.347 回答