linux进程线程下简单的消费者和生产者

在大家学习进程或者线程的时候肯定都会遇到生产者和消费者问题,也称为有界缓冲区。生产者消费者和现实中类似,只是在编程中一切都是数据而已,生产者和消费者简单的有一对一的关系,复杂的就有一对多、多对一、多对多的关系,要注意的是生产者和消费者都必须是在操作一块内存或者文件。在这里我仅为了熟练线程操作,使用线程来完成,并选则简单的增减数字来模拟生产者消费者关系,为了保证每一个线程可以执行完成在这里应用了互斥锁pthread_mutex_lock(pthread_mutex_t mutex)和等待唤醒pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t mutex)、pthread_cond_signal(pthread_cond_t* cond)函数,详细使用查阅man手册3;下面我们来看看图解和代码实现。

1、一对一的生产者和消费者:

这里写图片描述
代码:

#include<iostream>
#include<pthread.h>
#include<unistd.h>
using namespace std;
int count = 0;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_cond_t cond1 = PTHREAD_COND_INITIALIZER;
void *Product(void *arg)
{
    //pthread_mutex_lock(&mutex);
    while(1)
    {
        pthread_mutex_lock(&mutex);
        //int index = *(int *)arg;
        if(count >= 500)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }

}
void *Consumer(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
int main()
{
    pthread_t tid[2];
    while(1)
    {
        pthread_create(&tid[0],NULL,Product,NULL);
        pthread_create(&tid[1],NULL,Consumer,NULL);
        pthread_join(tid[0], NULL);
        pthread_join(tid[1], NULL);
        break;
    }
    return 0;
}

这里写图片描述

2、一对多的生产者和消费者们:

这里写图片描述

#include<iostream>
#include<unistd.h>
#include<pthread.h>
using namespace std;
int count = 0;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_cond_t cond1 = PTHREAD_COND_INITIALIZER;
void *Product(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }

}
void *Consumer1(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer1:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer2(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer2:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer3(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer3:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer4(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer4:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
int main()
{
    pthread_t tid[5];
    while(1)
    {
        pthread_create(&tid[0],NULL,Product,NULL);
        pthread_create(&tid[1],NULL,Consumer1,NULL);
        pthread_create(&tid[2],NULL,Consumer2,NULL);
        pthread_create(&tid[3],NULL,Consumer3,NULL);
        pthread_create(&tid[4],NULL,Consumer4,NULL);
        for(int i=0; i<5; ++i)
        {
            pthread_join(tid[i], NULL);
        }
    }
    return 0;
}

这里写图片描述

3、多对一的生产者们和消费者:

这里写图片描述
代码:

#include<iostream>
#include<unistd.h>
#include<pthread.h>
using namespace std;
int count = 0;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_cond_t cond1 = PTHREAD_COND_INITIALIZER;
void *Product1(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product1:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }

}
void *Product2(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product2:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Product3(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product3:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
int main()
{
    pthread_t tid[4];
    while(1)
    {
        pthread_create(&tid[0],NULL,Product1,NULL);
        pthread_create(&tid[1],NULL,Product2,NULL);
        pthread_create(&tid[2],NULL,Product3,NULL);
        pthread_create(&tid[3],NULL,Consumer,NULL);
        for(int i=0; i<4; ++i)
        {
            pthread_join(tid[i], NULL);
        }

    }
    return 0;
}

这里写图片描述

4、多对多的生产者和消费者们:

这里写图片描述

#include<iostream>
#include<unistd.h>
#include<pthread.h>
using namespace std;
int count = 0;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_cond_t cond1 = PTHREAD_COND_INITIALIZER;
void *Product1(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product1:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }

}
void *Product2(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product2:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Product3(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count >= 15)
        {
            pthread_cond_signal(&cond1);
            pthread_cond_wait(&cond, &mutex);
        }
        ++count;
        cout<<"This is product3:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer1(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer1:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer2(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer2:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer3(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer3:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
void *Consumer4(void *arg)
{
    while(1)
    {
        pthread_mutex_lock(&mutex);
        if(count <= 0)
        {
            pthread_cond_signal(&cond);
            pthread_cond_wait(&cond1,&mutex);
        }
        --count;
        cout<<"This is Consumer4:> "<<count<<endl;
        pthread_mutex_unlock(&mutex);
    }
}
int main()
{
    pthread_t tid[7];
    while(1)
    {
        pthread_create(&tid[0],NULL,Product1,NULL);
        pthread_create(&tid[1],NULL,Product2,NULL);
        pthread_create(&tid[2],NULL,Product3,NULL);
        pthread_create(&tid[3],NULL,Consumer1,NULL);
        pthread_create(&tid[4],NULL,Consumer2,NULL);
        pthread_create(&tid[5],NULL,Consumer3,NULL);
        pthread_create(&tid[6],NULL,Consumer4,NULL);
        for(int i=0; i<7; ++i)
        {
            pthread_join(tid[i], NULL);
        }

    }
    return 0;
}

这里写图片描述
在最后也说一下本人再学习线程中遇到的一个疑问就是创建简单的多线的时候,线程的创建先后顺序会乱,这是因为现在的电脑都是四核四线或者四核八线的配置,在程序执行的时候短时间会把每个线程的创建分配给每个内核的线程同时执行,由于不一定每个内核的线程都是空闲的所以会出现创建顺序的先好颠倒现象,并不是我们想象的线程有缓存区。
这里写图片描述
这里写图片描述
这里写图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值