• 11243阅读
  • 2回复

用Qt写的生产者消费者问题 [复制链接]

上一主题 下一主题
离线tiancaiamao
 

只看楼主 倒序阅读 楼主  发表于: 2009-05-31
学习线程同步中...自己用Qt做了个经典的生产者消费者问题,
代码贴出来.附件也可下载
//单生产者,多消费者,多缓冲区
#include <QtCore/QCoreApplication>
#include <QSemaphore>
#include <QThread>
#include <QMutex>
#include <iostream>
using namespace std;
QSemaphore vacancy(5);       //空位资源,
QSemaphore produce(0);              //产品数量
QMutex mutex;                   //互斥锁
int buffer[5];              //缓冲区可以放5个产品
int numtaken=60;
int takei=0;
class Producer:public QThread
{
    public:
    void run();
};
void Producer::run()        //生产者线程
{
    for(int i=0;i<60;i++)       //生产60次产品
    {
        vacancy.acquire();      //P(s1)操作原语
        buffer[i%5]=i;
        printf("生产出了%d\n",i);
        produce.release();      //V(s2)操作原语
    }
}
class Consumer:public QThread
{
    public:
    void run();
};
void Consumer::run()        //消费者线程
{
    while(numtaken>1)
    {
        produce.acquire();      //P(s2)操作原语
        mutex.lock();                //从缓冲区取出一个产品...多个消费者,不能同时取出,故用了互斥锁
        printf("%ul::从buffer[%d]拿走了%d \n",currentThreadId(),takei%5,buffer[takei%5]);
        takei++;
        numtaken--;
        mutex.unlock();
        vacancy.release();      //V(s1)操作原语
    }
}
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    Producer producer;
    Consumer consumerA;
    Consumer consumerB;
    producer.start();
    consumerA.start();
    consumerB.start();
    producer.wait();
    consumerA.wait();
    consumerB.wait();
    return 0;
}
描述:生产者消费者问题
附件: main.cpp (2 K) 下载次数:119
离线adever

只看该作者 1楼 发表于: 2013-05-26
经典的问题
离线fjb2080

只看该作者 2楼 发表于: 2013-05-28
把QT里的例子抄上来有意思吗?
快速回复
限100 字节
 
上一个 下一个