多线的的同步—条件变量

//reader_writer.c

#include <pthread.h>
#include <stdio.h>
#include <unistd.h>

/* 写者写完通知读者去读
读者读完通知写者去写 */

typedef struct{
    int value;
    
    int r_wait;
    pthread_mutex_t r_mutex;
    pthread_cond_t r_cond;
    
    int w_wait;
    pthread_mutex_t w_mutex;
    pthread_cond_t w_cond;
}Storage;

void set_value(Storage *s, int value)
{
    s->value = value;
}

int get_value(Storage *s)
{
    return s->value;
}

void *set_fn(void *arg)
{
    Storage *s = (Storage *)arg;
    int i = 0;
    for(; i < 100; i++){
        set_value(s, i+100);
        printf("writer write %d\n",i+100);
        pthread_mutex_lock(&s->r_mutex);
        //判断读者是否调用wait函数,如果调用了wait函数,那么写者就调用broadcast唤醒读者
        while(s->r_wait == 0){
            pthread_mutex_unlock(&s->r_mutex);
            sleep(1);
            pthread_mutex_lock(&s->r_mutex);
        }
        s->r_wait = 0;
        pthread_mutex_unlock(&s->r_mutex);
        pthread_cond_broadcast(&s->r_cond);
        
        //设置写者调用了wait函数,等待读者通知
        pthread_mutex_lock(&s->w_mutex);
        s->w_wait = 1;
        pthread_cond_wait(&s->w_cond, &s->w_mutex);
        pthread_mutex_unlock(&s->w_mutex);
    }
    
    return (void *)0;
}

void *get_fn(void *arg)
{
    Storage *s = (Storage *)arg;
    int i = 0;
    for(; i < 100; i++){
        //设置读者调用了wait函数,等待写者通知(r_wait和读者的wait函数绑定,1表示调用了wait函数)
        pthread_mutex_lock(&s->r_mutex);
        s->r_wait = 1;
        pthread_cond_wait(&s->r_cond, &s->r_mutex);
        pthread_mutex_unlock(&s->r_mutex);
        printf("reader read %d\n",get_value(s));
        
        //读者通知写者再写
        pthread_mutex_lock(&s->w_mutex);
        while(s->w_wait == 0){
            pthread_mutex_unlock(&s->w_mutex);
            sleep(1);
            pthread_mutex_lock(&s->w_mutex);
        }
        s->w_wait = 0;
        pthread_mutex_unlock(&s->w_mutex);
        pthread_cond_broadcast(&s->w_cond);
    }
    
    return (void *)0;
}

int main()
{
    pthread_t reader,writer;
    
    Storage s;
    s.r_wait = 0;
    pthread_mutex_init(&s.r_mutex, NULL);
    pthread_cond_init(&s.r_cond, NULL);
    
    s.w_wait = 0;
    pthread_mutex_init(&s.w_mutex, NULL);
    pthread_cond_init(&s.w_cond, NULL);
    
    if(pthread_create(&reader, NULL, get_fn, (void *)&s) < 0){
        printf("pthread_create failed\n");
    }
    
    if(pthread_create(&writer, NULL, set_fn, (void *)&s) < 0){
        printf("pthread_create failed\n");
    }
    
    pthread_join(reader, NULL);
    pthread_join(writer, NULL);
    
    pthread_mutex_destroy(&s.r_mutex);
    pthread_mutex_destroy(&s.w_mutex);
    
    pthread_cond_destroy(&s.r_cond);
    pthread_cond_destroy(&s.w_cond);
    
    return 0;
}

 

posted @ 2023-03-26 22:45  踏浪而来的人  阅读(12)  评论(0编辑  收藏  举报