mmap(内存映射, memory, map)函数的作用是建立一段内存,使它能够被两个或更多个程序读写。
下面的程序主要分为三段:
第一段是写入数据到一个文件中,
第二个段是使用fread的传统方法来进行更改内容
第三段是使用mmap进行内存映射进行操作
#include<unistd.h>
#include<stdio.h>
#include<sys/mman.h>
#include<fcntl.h>
#include<stdlib.h>
typedef struct {
int integer;
char string[24];
} RECORD;
#define NRECORDS (100)
int main()
{
RECORD record, *mapped;
int i, f;
FILE *fp;
//第一段
fp = fopen("records.dat", "w+");
for(i = 0; i < NRECORDS; i++)
{
record.integer = i;
sprintf(record.string, "RECORD-%d\n", i);
fwrite(&record, sizeof(record), 1, fp);
}
fflush(fp);
//第二段
fp = fopen("records.dat", "r+");
fseek(fp, 43*sizeof(record), SEEK_SET);
fread(&record, sizeof(record), 1, fp);
printf("%s %d\n", record.string, record.integer);
record.integer = 143;
sprintf(record.string, "RECORD-%d\n", record.integer);
fseek(fp, 43*sizeof(record), SEEK_SET);
fwrite(&record,sizeof(record), 1, fp);
fflush(fp);
//第三段
f = open("records.dat", O_RDWR);
mapped = (RECORD *)mmap(0, NRECORDS*sizeof(record),
PROT_READ|PROT_WRITE, MAP_SHARED, f, 0);
mapped[43].integer = 243;
sprintf(mapped[43].string, "RECORD-%d\n", mapped[43].integer);
msync((void *)mapped, NRECORDS*sizeof(record), MS_ASYNC);
munmap((void *)mapped, NRECORDS*sizeof(record));
close(f);
fclose(fp);
}
注意:在进行第二段操作的时候,一定要调用fflush()函数,因为stdio库会对数据进行缓冲,并不会立即写入到磁盘上,fwrite()函数可以确保在程序继续执行重要的操作之前,数据已经都被写入到磁盘中,如果没有讲缓存数据写入到磁盘中后面的操作很容易出错。当然也可以选择使用fclose()函数,这个函数默认会执行fflush()函数.