c中带有信号量的临界区
Critical section with semaphores in c
我试图让两个进程修改一个公共变量,同时相互排斥。我期望这段代码的输出是
1
2个
要么
2个
1
但我一直在
1个
1.
我试过在进入临界区之前让进程进入睡眠状态,但它们总是以相同的速度执行所有步骤并一起进入临界区。我该如何解决?
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/sem.h>
#include <sys/ipc.h>
#include <sys/shm.h>
static struct sembuf buf;
void enter(int semid, int semnum){
buf.sem_num = semnum;
buf.sem_op = 1;
buf.sem_flg = 0;
if (semop(semid, &buf, 1) == -1){
perror("Opening semaphore");
exit(1);
}
}
void leave(int semid, int semnum){
buf.sem_num = semnum;
buf.sem_op = -1;
buf.sem_flg = 0;
if (semop(semid, &buf, 1) == -1){
perror("Closing semaphore");
exit(1);
}
}
int main(int argc, char* argv[]){
int semid;
int i=0;
semid = semget(45281, 1, IPC_CREAT|0600);
if (semid == -1){
perror("Creating array of sems");
exit(1);
}
if (semctl(semid, 0, SETVAL, (int)1) == -1){
perror("Setting value to 1");
exit(1);
}
fork();
enter(semid,0);
i++;
leave(semid, 0);
printf("%d\n",i);
}
fork 操作为子进程创建一个单独的地址space,它是父进程的精确副本。因此,值为 0 的变量 i
将被复制到您正在生成的子进程中,并且有自己独立的存在,这就是为什么您在两个打印中看到 i
值为 1 的原因。
我试图让两个进程修改一个公共变量,同时相互排斥。我期望这段代码的输出是
1 2个 要么 2个 1
但我一直在 1个 1.
我试过在进入临界区之前让进程进入睡眠状态,但它们总是以相同的速度执行所有步骤并一起进入临界区。我该如何解决?
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/sem.h>
#include <sys/ipc.h>
#include <sys/shm.h>
static struct sembuf buf;
void enter(int semid, int semnum){
buf.sem_num = semnum;
buf.sem_op = 1;
buf.sem_flg = 0;
if (semop(semid, &buf, 1) == -1){
perror("Opening semaphore");
exit(1);
}
}
void leave(int semid, int semnum){
buf.sem_num = semnum;
buf.sem_op = -1;
buf.sem_flg = 0;
if (semop(semid, &buf, 1) == -1){
perror("Closing semaphore");
exit(1);
}
}
int main(int argc, char* argv[]){
int semid;
int i=0;
semid = semget(45281, 1, IPC_CREAT|0600);
if (semid == -1){
perror("Creating array of sems");
exit(1);
}
if (semctl(semid, 0, SETVAL, (int)1) == -1){
perror("Setting value to 1");
exit(1);
}
fork();
enter(semid,0);
i++;
leave(semid, 0);
printf("%d\n",i);
}
fork 操作为子进程创建一个单独的地址space,它是父进程的精确副本。因此,值为 0 的变量 i
将被复制到您正在生成的子进程中,并且有自己独立的存在,这就是为什么您在两个打印中看到 i
值为 1 的原因。