事例代码:
//------------------------------------------------mmap.c-----------------------------------------------------------
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
#include <sys/mman.h>
int main(int argc, char **argv)
{
int fd = -1;
struct stat f_stat;
unsigned char *start = NULL;
if (argc != 2)
return -1;
if ((fd = open(argv[1], O_RDONLY)) == -1)
return -1;
if (fstat(fd, &f_stat))
return -1;
if ((start = mmap(start, f_stat.st_size, PROT_READ, MAP_PRIVATE, fd, 0)) == MAP_FAILED)
return -1;
if (munmap(start, f_stat.st_size))
return -1;
close(fd);
}
//-------------------------------file end-------------------------------------------------------------------------------
mmap()是将指定的文件利用虚拟内存技术映射到内存中去,在内存中建立页表项,但mmap()调用并没有立即在内存中并没有建立页表项,只有使用到某个地址空间时才给此页面分配空间,要涉及到页面置换,因而需要有一定的物理内存做支撑,内存太小的话刚置入内存中的页面又要被交换到磁盘上,mmap的性能将大打折扣。
mmap的优点主要在为用户程序随机的访问,操作,文件提供了一个方便的操作方法;其次就是为不同进程共享大批量数据提供高效的手段;另外就是对特大文件(无法一次性读入内存)的处理提供了一种有效的方法。
madvise():
mmap()虽然为数据分配了连续的内存单元,但是mmap()后并没有立即读入数据,而是通过产生缺页中断再读入数据。
例如当需要访问第一个字节的数据时,这时系统检测到内存中并没有需要的数据,这时产生一个缺页中断,再从磁盘中读入1页(4096)的数据,
当访问第4097字节数据时,又会产生一次缺页中断,读入数据....,依此类推,直到读入所有数据
显然,这会极大的影响系统性能,因为频繁的缺页中断会打断CPU的工作流程
通过madvise()可以解决这个问题,读入所需的数据,避免频繁的中断