IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

[Sémaphores] modèle producteur consommateur


Sujet :

C

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2012
    Messages : 3
    Points : 4
    Points
    4
    Par défaut [Sémaphores] modèle producteur consommateur
    Bonjour à tous, j'ai vraiment du mal avec les sémaphores un peu d'aide serai le bien venu, j'ai cherché partout mais j'ai pas réussi à trouvé
    Voilà l'énoncé du programme :
    Un processus P crée des bonbons et un processus C en prend. Ils ont une vitrine en commun où sont placés les bonbons.
    Les 2 processus tournent indéfiniment.
    La vitrine ne peut pas être touché par plus d'une personne à la fois.
    Si la vitrine est pleine, le processus P arrête de créer des bonbons.
    Si la vitrine est vide, le processus C arrête de prendre des bonbons.
    Soit M le nombre max de bonbons que la vitrine peut contenir.

    La structure du projet est la suivante :
    PC-ini.c : crée les sémaphores
    P.c : le producteur qui rajoute un bonbon quand la vitrine n'est pas pleine
    C.c : le consommateur qui prend un bonbon quand la vitrine n'est pas vide

    J'ai fait PC-ini.c

    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
     
    #include<stdio.h>
    #include<stdlib.h>
    #include<errno.h>
    #include<sys/types.h>
    #include<sys/ipc.h>
    #include<sys/sem.h>
     
    #define M 25
     
    union semun
    {
        int val;
        struct semid_ds *buf;
        unsigned short *array;
    } arg;
     
    int main (void)
    {
        key_t key;
        int semid;
     
        key = ftok("/tmp", 'P');
     
        if(key == -1)
        {
            perror("ftok fails ");
            exit(1);
        }
     
        semid = semget(key,3,0600|IPC_CREAT);
        if(semid == -1)
        {
            perror("semget fails ");
            exit(2);
        }
     
        arg.val = M;
        semctl(semid,0,SETVAL,arg); /* nombre de place libre dans la vitrine */
        arg.val = 1;
        semctl(semid,1,SETVAL,arg); /* assure l'exclusion mutuelle */
        arg.val = 0;
        semctl(semid,2,SETVAL,arg); /* nombre de bonbon dans la vitrine */
     
        exit(0);
    }
    pour le P.c j'ai un soucis, je sais pas comment faire pour qu'il ne fasse rien si la vitrine est pleine
    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
     
    #include<stdio.h>
    #include<stdlib.h>
    #include<sys/ipc.h>
    #include<errno.h>
    #include<sys/sem.h>
    #include<sys/types.h>
     
    #define M 25
     
    int main (void)
    {
        int semid, n;
        key_t key;
        struct sembuf in[2] = {{1,-1,0},{2,1,0}}; /* quand on entre on met sem1 à 0  et on incrémente le nombre de bonbon dans la vitrine */
        struct sembuf out = {1,1,0}; /* quand on sort on met sem1 à 1*/
     
        key = ftok("/tmp", 'P');
        if(key == -1)
        {
            perror("ftok fails ");
            exit(1);
        }
     
        semid = semget(key,0,0);
        if(semid == -1)
        {
            perror("semget fails ");
            exit(2);
        }
     
        srand(time(NULL));
     
        while(1)
        {
            n = 1 + rand()%3;
            semop(semid,in,2);
            printf("Nombre de bonbon %d\n", semctl(semid,0,GETVAL,arg.array)); 
    		/* je prense pouvoir récupérer arg.array pour tester si c'est égal à M mais je sais pas comment faire pour récupérer cette structure */
            sleep(n);
            semop(semid,&out,1);
        }
    }
    J'ai pas fait le C.c mais je pense que c'est le même principe que P.c donc une fois que j'aurai compris comment faire avec P ce sera bon, j'espère.

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 518
    Points
    41 518
    Par défaut
    J'ai du mal à voir pourquoi tu as besoin d'un troisième sémaphore pour l'exclusion mutuelle, quand tu n'as qu'un seul producteur et un seul consommateur.

    Pour faire que le producteur ne fasse rien quand la vitrine est pleine, c'est simple: Tu le fais attendre sur le sémaphore "places libres".

    PS: pourquoi déclarer arg comme variable globale?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Questions sur BlockingQueue<T> (Modèle producteur / consommateur)
    Par Gugelhupf dans le forum Général Java
    Réponses: 1
    Dernier message: 05/11/2013, 20h32
  2. Sémaphores Producteur consommateur Windows
    Par Artusamak dans le forum Windows
    Réponses: 4
    Dernier message: 06/04/2007, 09h40
  3. Interface producteur/consommateur utilisant SWING
    Par El pistol dans le forum AWT/Swing
    Réponses: 17
    Dernier message: 03/04/2006, 15h06
  4. [Threads]Producteur - Consommateur - Filemessages
    Par slim dans le forum Concurrence et multi-thread
    Réponses: 10
    Dernier message: 08/03/2006, 18h57
  5. Réponses: 8
    Dernier message: 09/02/2006, 18h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo