线程的互斥锁和条件变量通信机制

  1 #include <stdio.h>
  2 #include <stdlib.h>
  3 #include <time.h>
  4 #include <pthread.h>
  5 
  6 #define BUFFER_SIZE 2
  7 struct prodcons
  8 {
  9     int buffer[BUFFER_SIZE];
 10     pthread_mutex_t lock;
 11     int readpos,writepos;
 12     pthread_cond_t notempty;
 13     pthread_cond_t notfull;
 14 };
 15 
 16 void init(struct prodcons *prod)
 17 {
 18     pthread_mutex_init(&prod->lock,NULL);
 19     pthread_cond_init(&prod->notempty,NULL);
 20     pthread_cond_init(&prod->notfull,NULL);
 21     prod->readpos=0;
 22     prod->writepos=0;
 23 }
 24 
 25 void put(struct prodcons *prod, int data)
 26 {
 27     pthread_mutex_lock(&prod->lock);
 28     while((prod->writepos+1)%BUFFER_SIZE==prod->readpos)
 29     {
 30         printf("producer wait for not full\n");
 31         pthread_cond_wait(&prod->notfull,&prod->lock);
 32     }
 33     prod->buffer[prod->writepos]=data;
 34     prod->writepos++;
 35     if(prod->writepos>=BUFFER_SIZE)
 36         prod->writepos=0;
 37     pthread_cond_signal(&prod->notempty);
 38     pthread_mutex_unlock(&prod->lock);
 39 }
 40 
 41 int get(struct prodcons *prod)
 42 {
 43     int data;
 44     pthread_mutex_lock(&prod->lock);
 45     while(prod->writepos==prod->readpos)
 46     {
 47         printf("consumer wait for not empty\n");
 48         pthread_cond_wait(&prod->notempty,&prod->lock);
 49     }
 50     data=prod->buffer[prod->readpos];
 51     prod->readpos++;
 52     if(prod->readpos>=BUFFER_SIZE)
 53         prod->readpos=0;
 54     pthread_cond_signal(&prod->notfull);
 55     pthread_mutex_unlock(&prod->lock);
 56     return data;
 57 }
 58 
 59 #define OVER (-1)
 60 
 61 struct prodcons buffer;
 62 
 63 void *producer(void * data)
 64 {
 65     int n;
 66     for(n=1;n<=5;n++)
 67     {
 68         printf("producer sleep 1 second...\n");
 69         sleep(1);
 70         printf("put the %d product\n",n);
 71         put(&buffer,n);
 72     }
 73     for(n=6;n<=10;n++)
 74     {
 75         printf("producer sleep 3 second...\n");
 76         sleep(3);
 77         printf("put the %d product\n",n);
 78         put(&buffer,n);
 79     }
 80     put(&buffer,OVER);
 81     printf("producer stopped\n");
 82     return NULL;
 83 }
 84 
 85 void *consumer(void *data)
 86 {
 87     int d=0;
 88     while(1)
 89     {
 90         printf("consumer sleep 2 second...\n");
 91         sleep(2);
 92         d=get(&buffer);
 93         printf("get the %d product\n",d);
 94         if(d==OVER)
 95             break;
 96     }
 97     printf("consumer stopped\n");
 98     return NULL;
 99 }
100 
101 int main(int argc, char *argv[])
102 {
103     pthread_t th_a,th_b;
104     void *retval;
105     init(&buffer);
106     pthread_create(&th_a,NULL,producer,0);
107     pthread_create(&th_b,NULL,consumer,0);
108     pthread_join(th_a,&retval);
109     pthread_join(th_b,&retval);
110     return 0;
111 }

 

posted on 2014-06-16 09:08  lakeone  阅读(312)  评论(0编辑  收藏  举报

导航