一、简介
JVM通过操作系统的系统调用(system call)进行内存的申请,典型的就是mmap。
这里有个问题,中所周知glibc提供了我们常用的内存管理函数如malloc/free/realloc/memory/memset等,为什么JVM不直接使用这些函数呢?
因为glibc的函数也是通过mmap等系统调用来完成内存的分配的,所以再基于glibc函数,性能会低一些。
所以,JVM是直接通过mmap来管理内存的,目的是提高性能。
二、mmap
一种内存映射文件的方法,mmap将一个文件或者其它对象映射进内存。文件被映射到多个页上,如果文件的大小不是所有页的大小之和,最后一个页不被使用的空间将会清零。mmap在用户空间映射调用系统中作用很大。
mmap()必须以PAGE_SIZE为单位进行映射,而内存也只能以页为单位进行映射,若要映射非PAGE_SIZE整数倍的地址范围,要先进行内存对齐,强行以PAGE_SIZE的倍数大小进行映射。
mmap详细信息请百科。
三、内存保留和提交
操作系统对内存的分配管理分为两个阶段:保留(reserve)和提交(commit)。
保留阶段:应用进程告知系统从某一地址开始到后面的dwSize大小的连续虚拟内存需要提供给本程序使用,其它进程的分配操作不得再分配这段内存;
提交阶段:将虚拟地址映射到真是的物理内存中,这样这段内存就可以正常使用了。