Bonjour, je souhaite implémenter un sémaphore sur un secrétariat où une seule personne peut rentrer à la fois et N personnes doivent passer. J'ai écrit le code suivant :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
 
#include <stdio.h>
#include <stdlib.h>
#include <semaphore.h>
#include <time.h>
 
int g_alea(int i_min,int i_max);
 
int main(int argc,char **argv)
{
    pid_t pid;
    sem_t secretariat;
    int N,i;
 
    srand(time(NULL));
 
    if(argc != 2)
        return -1;
 
    N = atoi(argv[1]);
    sem_init(&secretariat,0,1);
 
    for(i=1;i<=N;i++)
    {
        pid = fork();
        if(pid > 0)
        {
            printf("nouveau\n");
            sem_wait(&secretariat);
            printf("secretariat pour %d\n",i);
            sleep(g_alea(4,6));
            printf("on sort\n");
            sem_post(&secretariat);
            wait(NULL);
        }
        else if(pid == 0)
        {
            sleep(g_alea(1,5));
            printf("nouveau\n");
            sem_wait(&secretariat);
            printf("secretariat pour %d\n",i+1);
            sleep(g_alea(4,6));
            sem_post(&secretariat);
            exit(0);
        }
        else
            return -1;
    }
 
    return 0;
}
 
int g_alea(int i_min,int i_max)
{
    int nb = i_max - i_min + 1;
    int nb2 = rand() % nb;
    return i_min + nb2;
}
Le problème est que le sem_wait ne se bloque pas lorsque la personne qui arrive en 2ème tente d'entrer. Est ce que quelqu'un aurait une petite idée concernant mon problème? Merci