我实际上并不明白内存映射文件是什么以及为什么我们使用它们以及它们适合操作系统的哪个部分。请用一个简单的例子解释一下。
谢谢
答案1
“内存映射”不是一种文件类型,而是一种访问方式。同一类型的文件可以由程序 A 正常读取,但可以由程序 B 进行内存映射。
通常(在大多数编程语言中),每个文件访问都需要单独的调用:
- 你首先
open
获取文件(获取“文件描述符”), seek
到所需位置(如有必要),read
一定数量的字节(将其从文件复制到 RAM 中),- …
seek
,read
,read
,seek
,write
,read
, 等等。
因此,如果您使用数据库文件等,则涉及大量系统调用,更不用说复制进和复制出的所有数据。(通常有方便的 seek+read 和 seek+write 调用,例如pread
在pwrite
Linux 上,但它们没有多大帮助。)
同时,内存映射允许程序访问文件就像 RAM 一样在open
读取文件之后,程序只需要一次mmap
调用来设置一个内存区域,之后就可以立即通过该“窗口”访问文件的内容——使用变量从文件读取,使用变量将内容写入文件。
这可以大大简化代码,并加快文件的加载和保存速度,因为程序知道数据将要存在,但操作系统实际上直到真正需要时才加载它。