Как синхронизировать процессы с помощью семафора
Скажем, у меня есть 3 процесса, включая родительский процесс, который я должен выполнить, я программирую в последовательности P3,P1,P2. Ребята, пожалуйста, помогите мне, как я могу начать вычисления с процесса P3.
Мне нужно, как {0,1,2,3,4,5,.. макс}
Для справки мой снимок кода:-
#define SEM_NAME "//test.mutex"
//#define SEM_NAME2 "//test2.mutex"
int main(int argc, char const *argv[]) {
int max = 0, i =0;
sem_t *sem;
sem_t *sem2;
pid_t pid, pid2;
sem = sem_open(SEM_NAME, O_CREAT, O_RDWR, 1);
sem_unlink(SEM_NAME);
if (sem==SEM_FAILED) {
printf("%s sem_open failed!", SEM_NAME);
return (-1);
}
// sem2 = sem_open(SEM_NAME2, O_CREAT, O_RDWR, 0);
// sem_unlink(SEM_NAME2);
// if (sem2==SEM_FAILED) {
// printf("%s sem_open failed!", SEM_NAME2);
// return (-1);
// }
printf("Enter the maximum number\n");
scanf("%d", &max);
pid = fork();
if(pid == 0)
{
i = 2;
pid2 = fork();
if(pid2 == 0)
{
i = 0;
}
else
{
sleep(2);
}
}
else
{
i = 1;
sleep(1);
}
//do
{
sem_wait(sem);
for (; i <= max;) {
printf("pid %d done and value is %d\n", getpid(),i);
i = i + 3;
}
sem_post(sem);
} //while(i <= max);
wait(NULL);
return 0;
}
когда я запускаю программу, я получаю следующий вывод {0,3,,6,1,4,7,2,5,8}
Мне нужен способ, которым первый процесс должен печатать число, и он должен позволить другому процессу печатать его номер, а на последней трети должен печатать.
Мне нужен способ, чтобы каждый и добирался туда последовательно.
Надеюсь, я согласен с вопросом
1 ответ
Вот псевдокод того, как вы можете достичь порядка P3, P1, P2
//semaphores for P1, P2, P3 respectively
semaphore s1=0;
semaphore s2=0;
semaphore s3=1; //coz P3 needs to go first
//for p3
wait(s3)
//do p3 here
signal(s1) //signal for P1 to start
//for p1
wait(s1)
//do p1
signal(s2) // signal to start P2
//for p2
wait(s2)
//do p2
signal(s3) //signal to start p3 again if that is required or you can omit this if not required