目录
内存共享是进程之间最快的通信方式,为什么呢?
例:管道通信,都是以文件为媒介,需要使用系统调用将数据传入给内核,而共享内存直接与内存进行交互。
进程间通信的本质就是让进程看到同一块系统提供的资源,共享内存就是让不同进程看到同一块内存,用内存作为媒介,让两个不同进程通信。
示意图
共享内存系统调用接口
1.shmget
key:就是一个关键值,让不同的进程,通过一个key值找到同一个共享内存。
size:就是开辟多大的共享内存,共享内存的开辟是以4kb为单位的,size的大小建议设置4*n,因为即使size为7,还是会开辟8个字节的内存,剩下的一个字节就浪费了。
shmlg:想要怎么创建共享内存
IPC_CREAT:如果key对应的共享内存不存在就创建,存在就获取。
IPC_EXCL:如果共享内存存在,就出错返回,单独使用没有意义,要配合IPC_CREAT。
返回值:成功共享内存的标识符被返回,失败-1被返回,错误码被设置去指示错误。
2.ftok
ftok使用参数pathname和最少8个有效位的参数proj_id(必须不为0)生成一个key_t类型的System V IPC密钥,适用于msgget,semget,shmget这三个函数。
pathname:指定一个路径
proj_id:8个有效位的参数
成功生成key_t类型的密钥被返回,失败-1被返回,错误码被设置。
3.shmat&&shmdt
创建共享内存之后,需要shmat挂接到进程中,本