Linux Shared Memory Synchronization

后端 未结 4 554
天命终不由人
天命终不由人 2021-02-06 03:24

I have implemented two applications that share data using the POSIX shared memory API (i.e. shm_open). One process updates data stored in the shared memory segment

相关标签:
4条回答
  • 2021-02-06 03:50

    First, really benchmark to know if performance is important. The cost of these things is often overestimated. So if you don't find that the access to the control structure is of same order of magnitude than the writes, just take whatever construct is semantically the best for your use case. This would be the case usually if you'd have some 100 bytes written per access to the control structure.

    Otherwise, if the control structure is the bottleneck, you should perhaps avoid to use them. C11 has the new concept of _Atomic types and operations that can be used in cases where there are races in access to data. C11 is not yet widely implemented but probably all modern compilers have extensions that implement these features already.

    0 讨论(0)
  • 2021-02-06 04:00

    If efficiency is important, I would go with process-shared mutexes and condition variables.

    AFAIR, each operation with a semaphore requires a syscall, so uncontended mutex should be faster than the semaphore [ab]used in mutex-like manner.

    0 讨论(0)
  • 2021-02-06 04:05

    Rather than a System V semaphore, I would go with a POSIX named semaphore using sem_open(), etc.

    0 讨论(0)
  • 2021-02-06 04:10

    Might as well make this an answer.

    You can use sem_init with pshared true to create a POSIX semaphore in your shared memory space. I have used this successfully in the past.

    As for whether this is faster or slower than a shared mutex and condition variable, only profiling can tell you. On Linux I suspect they are all pretty similar since they rely on the "futex" machinery.

    0 讨论(0)
提交回复
热议问题