标签:length sha 调用 const size 实现 缓冲 区域 flag
使用这种方法,首先应通知内核,将一个指定文件映射到存储区域中。这个映射工作可以通过mmap函数来实现。不通过IO。直接操作内存,效率更高。
函数原型
#include <sys/mman.h>
void *mmap(void *addr, size_t length, int prot, int flags,int fd, off_t offset);
使用MAP_SHARED的时候,要注意打开文件的权限>=映射区权限。因为如果文件没有写权限,映射区有写权限,那么映射区是无法写入文件的,这和MAP_SHARED的目的相反。如是MAP_PRIVATE就没有此要求。
另外,文件打开权限起码要是可读的,如果不可读,那么怎么读取数据映射到内存呢?
函数原型:
#include <sys/mman.h>
int munmap(void *addr, size_t length);
此函数较为简单,释放映射区,首地址为addr,长度为length.
实现进程间的通信,写进程将一份文件映射到内存,并且每秒写入(覆盖写入)不同的字符串,读进程一直去读。
写进程:
struct Person{
char name[30];
int num;
};
int main(int argc, char const* argv[])
{
//打开文件,作为映射
int fd = open("memTest2.txt", O_RDWR);
//int fd = open("memTest2.txt", O_RDWR);
int length = sizeof(struct Person);
ftruncate(fd, length);
printf("fd=%d\n", fd);
//映射
struct Person* mem = (struct Person*)mmap(0, length, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
if (mem == MAP_FAILED) {
perror("mmap err");
return -1;
}
printf("映射区地址:%0x\n", mem);
int num = 1;
while (1) {
mem->num = num++;
sprintf(mem->name, "I am a Person%03d", mem->num);
sleep(1);
}
//释放
munmap(mem, length);
close(fd);
return 0;
}
读进程:
struct Person{
char name[30];
int num;
};
int main(int argc, char const* argv[])
{
//打开文件,作为映射
int fd = open("memTest2.txt", O_RDWR);
int length = sizeof(struct Person);
printf("fd=%d\n", fd);
//映射
struct Person* mem = (struct Person *)mmap(0, length, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
if(mem == MAP_FAILED)
{
perror("mmap err");
return -1;
}
printf("映射区地址:%0x\n", mem);
while (1) {
printf("name=%s,num=%d\n", mem->name,mem->num);
sleep(1);
}
//释放
munmap(mem, length);
close(fd);
return 0;
}
标签:length sha 调用 const size 实现 缓冲 区域 flag
原文地址:https://www.cnblogs.com/love-jelly-pig/p/10063442.html