问题描述
运行这段代码应该会使程序中断增加malloc_counts * _SC_PAGESIZE
左右,而我每次都会得到固定的程序中断,所以这是为什么。 malloc应该调用brk
或sbrk
,它们本身会将大小取整并传递到下一页(需要做一些额外的工作)。那是怎么回事?
#include <stdio.h>
#include <malloc.h>
#include <unistd.h>
int main(){
const long malloc_counts = 10;
printf("PAGE SIZE: %ld\n",sysconf(_SC_PAGESIZE));
void* allocated_pool[malloc_counts];
for(int counter=0; counter < malloc_counts; counter++)
{
printf("program brk: %p\n",sbrk(0));
allocated_pool[counter] = malloc(127*4096);
}
}
解决方法
我想当然会使用优化
您的编译器会优化对malloc
的调用,因为它们未使用。因为malloc
调用已删除,所以没有任何变化,并且堆也没有移动。
而且glibc占用很多,因此该值必须足够大才能看到它。默认的M_MMAP_THRESHOLD
似乎是128 * 1024。因此,您必须选择一个足够大的值,但要低于mmap阈值才能看到glibc的差异。
禁用编译器优化并分配很多,堆将被移动。请尝试以下操作:
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
int main() {
printf("PAGE SIZE: %ld\n",sysconf(_SC_PAGESIZE));
#define malloc_counts 20
void *allocated_pool[malloc_counts];
for(int counter = 0; counter < malloc_counts; counter++) {
printf("program brk: %p\n",sbrk(0));
allocated_pool[counter] = malloc((size_t)127 * 1024);
*(void *volatile *)&allocated_pool[counter];
}
}