1、使用mmap函数,将物理内存映射到进程的虚拟地址空间,详解见链接https://blog.csdn.net/yangle4695/article/details/52139585
使用mmap(2)解决映射问题,需包含头文件#include<sys/mman.h>
void *mmap(void *addr,size_t length,int prot,int flags,int fd,off_t offset);
功能:
映射文件或设备到内存(linux操作系统之下,一切皆文件。文件是文件,设备也是文件)
UNIX网络编程第二卷进程间通信对mmap函数进行了说明。该函数主要用途有三个:
1、将一个普通文件映射到内存中,通常在需要对文件进行频繁读写时使用,这样用内存读写取代I/O读写,以获得较高的性能;
2、将特殊文件进行匿名内存映射,可以为关联进程提供共享内存空间;
3、为无关联的进程提供共享内存空间,一般也是将一个普通文件映射到内存中。
参数:
addr:在虚拟空间映射的首地址(一般为NULL,由内核选定分配的空间起始地址)
length:虚拟空间映射的长度
prot:
PROT_NONE Pages may not be accessed
PROT_EXEC Pages may be executed
PROT_READ Pages may be read
PROT_WRITE Pages may be written
flags:(参数具体功能可使用man+2+函数名命令查询,其中2表示系统调用)
MAP_SHARED:对映射区域的写入数据会复制回文件内,而且允许其他映射该文件的进程共享。
MAP_PRIVATE: 对映射区域的写入操作会产生一个映射文件的复制,即私人的“写入时复制”(copy on write)对此区域作的任何修改都不会写回原来的文件内容。
上面两个参数选择一个,需要在按位与后面的其他参数。
MAP_ANONYMOUS:建立匿名映射。此时会忽略参数fd,不涉及文件,而且映射区域无法和其他进程共享。
MAP_FIXED 如果参数start所指的地址无法成功建立映射时,则放弃映射,不对地址做修正。通常不鼓励用此旗标。
MAP_DENYWRITE只允许对映射区域的写入操作,其他对文件直接写入的操作将会被拒绝。
MAP_LOCKED 将映射区域锁定住,这表示该区域不会被置换(swap)。
fd:
要映射到内存中的文件描述符。如果使用匿名内存映射时,即flags中设置了MAP_ANONYMOUS,fd设为-1。有些系统不支持匿名内存映射,则可以使用fopen打开/dev/zero文件,然后对该文件进行映射,可以同样达到匿名内存映射的效果。
offset:
文件映射的偏移量,通常设置为0,代表从文件最前方开始对应,offset必须是分页大小的整数倍。
返回值:
若映射成功则返回映射区的内存起始地址,否则返回MAP_FAILED(-1),错误原因存于errno 中。
错误:MAP_FAILED,同时errno被设置
成功:映射区域首地址
int munmap(。。。),略
使用包含头文件#include<sys/mman.h>
网友评论