循环调用malloc后程序中断不会改变吗?

问题描述

运行这段代码应该会使程序中断增加malloc_counts * _SC_PAGESIZE左右,而我每次都会得到固定的程序中断,所以这是为什么。 malloc应该调用brksbrk,它们本身会将大小取整并传递到下一页(需要做一些额外的工作)。那是怎么回事?

#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];
    }
}