malloc:匿名映射和魔术区域
我只是在摆弄内存映射,并希望查看用户空间虚拟内存区域映射。 写了一些像
char *ptr = NULL; printf("Allocating 300KB\n"); ptr = malloc (300*1024); printf("Allocated at %p.. sleeping\n", ptr); sleep (30); free (ptr); printf("Freed... sleeping\n"); sleep (30);
在运行程序时,pid上的pmap
将分配的区域显示为:
00007f73b1e57000 316K rw--- [ anon ]
而程序o / p说:
Allocated at 0x7f73b1e57010.. sleeping
对于我们称之为魔法区域的分配,这是16KB的额外分配吗? 在内核中,相应的vm_area_struct
将保存程序可见范围或魔术区域起始的整个范围?
差异不是16KB,而是16字节。 其中最可能对应于malloc必须在内存块之前分配的头,以便将块链接在一起等。
从任何具有内存管理单元的操作系统开始,使用MMU管理其所有内存(堆,代码空间,堆栈I / O内存),所有内存都存在于虚拟空间中,页表用于将虚拟地址转换为物理内容地址,到物理内存的映射取决于操作系统
malloc
将使用sbrk调用返回指向堆内存的指针,这反过来会增加堆大小,当访问此内存时,MMU将分配实际的物理页面并映射到虚拟地址。
根据pmap手册页,输出显示而不是malloc分配的内存块大小,而是虚拟映射大小。
"Virtual Mapping Size (Kbytes) The virtual size in kilobytes of each mapping."
有关快速实验,请检查从malloc返回的内存块大小是否应等于pmap
的输出。
为了certificate这一点,我使用此代码进行了快速测试
int main(int argc, char **argv) { char *timeBuf = (char *)malloc(100); printf("allocated address is %p\n",timeBuf); int i; for(i =0 ;i < atoi(argv[1]);i++) { } return 0; }
pmap输出是:
`0000000001338000 132K rw--- [ anon ]`
来自malloc的返回指针:
allocated address is 0x1338010
我认为16个字节是由malloc保存的,用于保存在前面的答案中提到的标题中。 您可以在程序中分配的内存只有100个字节,但pmap虚拟内存大小为132K
所以简单地回答你的问题不是这与魔术领域无关。