2
#include <stdlib.h>
#include <stdio.h>
#include <strings.h>
#include <sys/mman.h>
#include <time.h>

#define HUGEPAGE 2048*1024
void *normal_malloc(int len)
{
    void *ptr = malloc(len);
    bzero(ptr, len);
    return ptr;
}

void *trans_malloc(int len)
{
    void *ptr = NULL;
    int ret = posix_memalign(&ptr, HUGEPAGE, len);
    if(ret) perror("posix_memalign");
    ret = madvise(ptr, len, MADV_HUGEPAGE);
    bzero(ptr, len);
    return ptr;
}

void *mmap_malloc(int len)
{
    void *ptr = mmap(NULL, len, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS|MAP_HUGETLB, -1,0);
    return ptr;
}

int main(int argc, char **argv)
{
    char *ptr = NULL;
    int len = HUGEPAGE*256;
    srand(time(NULL));
    switch(argc){
        case 1: ptr = normal_malloc(len);break;
        case 2: ptr = trans_malloc(len);break;
        case 3: ptr = mmap_malloc(len); break;
    }

    long j = 0;
    for(int i=0;i<len;i++){
        j += ptr[rand()%len];
    }
    return 0;
}

我使用正常malloc的 andposix_memalignmmap测试性能。我的测试结果是: malloc耗时约29.7s,posix_memalign耗时约23.5s,mmapmalloc. 两者都posix_memalign使用mmap大页面。为什么一个有明显改善,另一个没有?我是否mmap以错误的方式使用?我不为 mmap 做 bzero 因为手册页说“它的内容被初始化为零”。

4

0 回答 0