mmap分配的是进程对应的虚拟内存,所以即使你执行mmap让它分配个3、5个GB的内存,它也会马上返回,但是这个时候系统的物理内存并没有分配好,只有当程序真正使用到这块内存时,才会触发缺页中断,分配物理内存。
褚霸的博客http://blog.yufeng.info/archives/tag/mmap上提到了通过MAP_POPULATE,实现mmap预分配内存的方法,即mmap函数返回时,对应的物理内存空间已经分配好了。
下面是一个测试代码:
#include <errno.h>
#include <sys/mman.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
int main()
{
void* buf = mmap64(NULL, 1024*1024*1024, PROT_READ|PROT_WRITE, MAP_POPULATE|MAP_PRIVATE|MAP_ANONYMOUS, 0, 0);
if (buf == MAP_FAILED) {
printf("mmap failed, %m\n", errno);
return 0;
}
printf("mmap buf success\n");
sleep(10);
return 0;
}
执行这个程序后,马上用free -g查看,果然空闲内存少了1GB,等10秒后程序退出,再用free -g查看,空闲内存多了1GB,说明该程序的确实现了内存的预分。