文章目录
- 补充知识
补充知识
进行通信的key值问题,进程要通信的对方进程怎么能保证对方能看到,并且看到的就是该进程创建的共享内存的。
所以就通过key值来标识共享内存,key值是几不重要,只要在系统里是唯一的即可。
这样server和client使用同一个key,只要key值相同,就是看到同一块内存。
key:对应共享内存key值
shmid:对应共享内存用户层标识的唯一值
owner:属于哪个进程
bytes:大小的字节数
nattch:链接的进程个数
status:状态
共享内存被挂接进用户空间,而用户空间不用经过系统调用,可以直接访问
所以共享内存用来通信,通信双方直接进行内存级的读写即可。
我们之前的pipe和fifo都要通过read和write来进行通信,是因为pipe和fifo都是OS进行管理的,不再用户空间下。
只要通信双方使用shm,一方直接向shm中写数据,另一方就可以立马看到。
所以共享内存是所有进程间通信(IPC)速度最快的!因为不需要过多拷贝。(不需要将数据给OS)
管道:
共享内存:
而我们之前发现共享内存缺乏访问控制!这样会带来并发问题。所以我们用管道为它进行了访问控制
ipcs -m
查看共享内存
ipcs -q
查看消息队列
ipcs -s
查看信号量
ipcrm -id
删除上面三个的指令