mmap方案:
通过mmap内存映射函数,进程A和进程B都将存储设备的同一个页映射到自己的地址空间
mmap()系统调用使得进程之间通过映射同一个普通文件实现共享内存。普通文件被映射到进程地址空间后,进程可以向访
问普通内存一样对文件进行访问,不必再调用read(),write()等操作。
void* mmap ( void * addr , size_t len , int prot , int flags , int fd , off_t offset )
mmap的作用是映射文件描述符fd指定文件的 [off,off + len]区域至调用进程的[addr, addr + len]的内存区域
参数fd为即将映射到进程空间的文件描述字,一般由open()返回,同时,fd可以指定为-1,此时须指定flags参数中的
MAP_ANON,表明进行的是匿名映射(不涉及具体的文件名,避免了文件的创建及打开,很显然只能用于具有亲缘关系的
进程间通信)
len和offset一看即明白。
prot 参数指定共享内存的访问权限。可取如下几个值的或:PROT_READ(可读) , PROT_WRITE (可写), PROT_EXEC (可执行), PROT_NONE(不可访问)
flags由以下几个常值指定:MAP_SHARED , MAP_PRIVATE , MAP_FIXED,其中,MAP_SHARED , MAP_PRIVATE必
选其一,而MAP_FIXED则不推荐使用。
参数addr指定文件应被映射到进程空间的起始地址,一般被指定一个空指针,此时选择起始地址的任务留给内核来完成。
数的返回值为最后文件映射到进程空间的地址,进程可直接操作起始地址为该值的有效地址。
获取到void*返回值之后,即可关闭文件对此指针进行操作。
进行写的进程,可将flag参数设为MAP_PRIVATE,以避免真实的修改文件。
shmget方案
首先
int shmget(key_t key, size_t size, int shmflg);
获取共享内存段的标识符;其中flag,一个进程用了IPC_CREAT|IPC_EXCL获取了,另一个进程就不用此参数了。
然后挂接void *shmat(int shmid, const void *shmaddr, int shmflg);返回共享存储段的指针
接下来就可以操作此内存了。
结束之后调用int shmdt(const void *shmaddr); 结束共享;
再调用int shmctl(int shmid, int cmd, struct shmid_ds *buf);销毁共享内存。