一尘不染

带pthread的进程间互斥

linux

我想使用互斥锁,该互斥锁将用于同步访问内存共享黑白中两个不同进程中的某些变量。我该如何实现。执行该代码示例将不胜感激。


阅读 270

收藏
2020-06-02

共1个答案

一尘不染

而是 使用初始化为的POSIX信号量1(请参见下文)sem_init用于未命名的信号灯或sem_open已命名的信号灯。

sem_t sem;

/* initialize using sem_init or sem_open */

sem_wait(&sem);
/* critical region */
sem_post(&sem);

最初发布此答案很多年后,必须对其进行更新。

实际上应该使用互斥对象而不是信号量
。R和kuga的评论(如下逐字复制)解释了原因。特别是,我发现kuga提到互斥锁只能post通过其最引人注目的锁定线程来编辑。


[R

sem_init需要共享非零的pshared参数,就像互斥锁将需要pshared属性一样。为此,没有理由更喜欢信号量而不是互斥量,实际上互斥量会更好,因为您可以使用健壮的互斥量,该互斥量可以处理(非常真实的)情况,即一个进程在持有锁的同时死亡。

库加

除R..`的帖子外,互斥锁只能由锁定它的线程发布。这通常是必需的,并且信号灯不提供此功能。因此,这不是正确答案,应该将Jeff的答案标记为正确答案。

2020-06-02