#include <limits.h>
#include <sys/mman.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h>
#include <stdio.h>
void errorMessage(char* message);
int main(int argc,char* argv[])
{
int file; //打开的文件描述符
int ret;//函数返回值临时变量
int offset;//文件偏移量
int page_offset;//大小等于页的正数倍的文件偏移量大小
int length;//缓冲区文件长度
struct stat statbuff;//文件状态结构体
ssize_t w_size;//写入文件的字节长度
void* pFile;//文件映射在内存中为位置的指针
//命令行参数1为文件名称 2为 文件偏移量 3为 文件长度
if(argc < 3 | argc > 4)
{perror("输入参数不正确");
}
file = open(argv[1],O_RDWR);
if(file == -1)
{
errorMessage("文件打开错误");
}
//读取文件的状态
ret = fstat(file,&statbuff);
if(ret == -1)
{
errorMessage("文件状态读取失败");
}
offset = atoi(argv[2]);
page_offset = offset & ~(sysconf(_SC_PAGESIZE) -1);//确保其为页大小的整数倍
if(offset >= statbuff.st_size)
{
errorMessage("文件偏移量大于等于文件长度");
}
//如果没有指定参数四则默认长度为文件的末尾
if(argc == 4)
{
length = atoi(argv[3]);
if(offset + length > statbuff.st_size)
{length = statbuff.st_size - offset;//如果文件长度大于文件剩余长度的话则处理为文件结尾的长度
}
}
else
{
length = statbuff.st_size - offset;
}
//进行mmap映射
pFile = mmap(NULL,offset - page_offset + length,PROT_READ,MAP_PRIVATE,file,page_offset);
//读取内存地址并打印到文件终端中去
w_size = write(1,pFile + offset - page_offset,length);
//因为page_offset的值肯定比offset的值小,也就是说给我们多映射了文件的一部分,我们得跳过那部分
if(w_size == -1)
{
errorMessage("写入到终端文件");
}
//关闭文件映射
munmap(page_offset,offset - page_offset + length);
//关闭文件描述符
close(file);
exit(0);
}
Mmap()内存与文件的映射测试函数代码
最新推荐文章于 2023-09-21 12:19:17 发布