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