| 12
 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;
} | 
Partager