【lesson47】进程通信之system V(共享内存)补充知识

文章目录

  • 补充知识

补充知识

进行通信的key值问题,进程要通信的对方进程怎么能保证对方能看到,并且看到的就是该进程创建的共享内存的。
所以就通过key值来标识共享内存,key值是几不重要,只要在系统里是唯一的即可。
这样server和client使用同一个key,只要key值相同,就是看到同一块内存。
【lesson47】进程通信之system V(共享内存)补充知识_第1张图片
【lesson47】进程通信之system V(共享内存)补充知识_第2张图片
key:对应共享内存key值
shmid:对应共享内存用户层标识的唯一值
owner:属于哪个进程
bytes:大小的字节数
nattch:链接的进程个数
status:状态

共享内存被挂接进用户空间,而用户空间不用经过系统调用,可以直接访问
所以共享内存用来通信,通信双方直接进行内存级的读写即可。

我们之前的pipe和fifo都要通过read和write来进行通信,是因为pipe和fifo都是OS进行管理的,不再用户空间下。

只要通信双方使用shm,一方直接向shm中写数据,另一方就可以立马看到。

所以共享内存是所有进程间通信(IPC)速度最快的!因为不需要过多拷贝。(不需要将数据给OS)

管道:
【lesson47】进程通信之system V(共享内存)补充知识_第3张图片
共享内存:
【lesson47】进程通信之system V(共享内存)补充知识_第4张图片
而我们之前发现共享内存缺乏访问控制!这样会带来并发问题。所以我们用管道为它进行了访问控制

ipcs -m 查看共享内存
ipcs -q 查看消息队列
ipcs -s 查看信号量

ipcrm -id 删除上面三个的指令

你可能感兴趣的:(linux,服务器,运维,Linux,进程通信)