gpt4 book ai didi

c - 管理共享内存中的互斥量

转载 作者:太空宇宙 更新时间:2023-11-04 01:10:52 25 4
gpt4 key购买 nike

我正在尝试在共享内存中创建互斥锁这一简单任务。我有以下代码来声明一段共享内存,并将其附加到 int*

int *mutex;

// allocate shared memory for mutex
if ((shmid2 = shmget(IPC_PRIVATE, 4, IPC_CREAT | 0666)) < 0) {
printf("Could not allocate shared memory for mutex: %d.\n", errno);
exit(errno);
}

if ((mutex = shmat(shmid2, NULL, 0)) == (int*)-1) {
printf("Could not attach shared memory for mutex: %d\n", errno);
exit(errno);
}

// set the mutex to one
mutex[0] = 1;

现在,我尝试定义一个关键部分,周围是锁定和解锁互斥量。 (在许多子进程之一中)。

while (*mutex == 0) ;
mutex[0] = 0;

// critical section

...

// end critical section

mutex[0] = 1;

但是,我发现这种技术不起作用,两个子进程可以同时进入临界区,没有太大问题(这种情况经常发生)。所以我想知道如何在不使用 pthreads 的情况下解决这个问题。

最佳答案

您的选择是:

  1. 使用 POSIX 信号量,而不是尝试使用共享内存自旋锁自行实现它们。请参阅 semop (2) 的文档以及相关功能的详细信息。

  2. 如果您必须使用共享内存信号量,则需要使用原子比较/交换。否则,两个进程可以同时看到 *mutex == 0 并同时将其设置为 1,而不会“注意到”另一个进程正在做同样的事情.

关于c - 管理共享内存中的互斥量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12682985/

25 4 0