同是共享内存,shm_open与shmget有什么差异?

  因为工作需要,这几天研究了一下共享内存。搞得自己也有点糊涂。糊涂在哪里?有两个共享内存的东西。仔细研究了之后,初步结论如下。

  shm_open:把共享内存以文件方式打开,这样就可以直接向文件中写入数据了。有以下注意事项:

  从了解的资料来看,硬盘可能有对应的文件。如果是真的,数据量大的时候,就存在一个性能问题。

  进程甲写数据,进程乙可能分两次收到。

  一个进程写,另外两个进程是否都能收到?

  如果使用select(),理论上不需要加锁。

  有人问,用管道是不是能实现同样功能?如果是一对一,管道可以;如果是多对一,还是这个更好。因为工作情况,没有更深入的研究。

  shmget():就是得到一个内存区, KEY相同情况下,各进程访问的是同一块内存。造型为指定类型后,直接操作访问。注意:

  访问进程间要加锁。这个锁也必须是共享内存锁。参考吾其他博文。

  写数据时,结构体中的缓冲区必须是已经声明足够大小,而不是一个指针需要时malloc。因为malloc的地址,其他进程访问不到。

猜你喜欢

转载自blog.csdn.net/quantum7/article/details/85049464