因为工作需要,这几天研究了一下共享内存。搞得自己也有点糊涂。糊涂在哪里?有两个共享内存的东西。仔细研究了之后,初步结论如下。
- shm_open
把共享内存以文件方式打开,这样就可以直接向文件中写入数据了。有以下注意事项:
- 从了解的资料来看,硬盘可能有对应的文件。如果是真的,数据量大的时候,就存在一个性能问题。
- 进程甲写数据,进程乙可能分两次收到。
- 一个进程写,另外两个进程是否都能收到?
- 如果使用select(),理论上不需要加锁。
有人问,用管道是不是能实现同样功能?如果是一对一,管道可以;如果是多对一,还是这个更好。因为工作情况,没有更深入的研究。
- shmget
就是得到一个内存区, KEY相同情况下,各进程访问的是同一块内存。造型为指定类型后,直接操作访问。注意:
- 访问进程间要加锁。这个锁也必须是共享内存锁。参考吾其他博文。
- 写数据时,结构体中的缓冲区必须是已经声明足够大小,而不是一个指针需要时malloc。因为malloc的地址,其他进程访问不到。