共享内存 同步、互斥

共享内存没有提供互斥机制,需要程序员自己实现。

1.对于多个进程共享的共享内存来说,惟一可靠的互斥机制 就是带SEM_UNDO的system V信号量

原因:

    某一个进程在持有锁期间意外退出,所持有的锁还没有来得及释放,这回造成 所有等待(P操作)这个锁的进程/线程死锁。

所以不建议使用POSIX 信号量或者互斥锁。

2.对于同步机制,可以使用POSIX匿名信号量 。

3 .对于异步通知机制,可以使用 FIFO 或者eventfd(>since Linux 2.6.27


4.关于原子的创建共享内存

(1)创建任何东西先带着O_CREAT | O_EXCL去创建,失败了则直接打开,这是原子性必备的。
(2)共享内存初始化之前如何同步? 设置mode的X位后开始初始化共享内存,结束后取消X位,任何进程打开共享内存后stat轮询检查X位是否复位,复位后才可以开始操作。

猜你喜欢

转载自blog.csdn.net/sunweiliang/article/details/80072105