linux 伪线程,Linux下面的线程锁,条件变量以及信号量的使用

本文介绍了一个C++实现的线程队列CThreadQueue,通过互斥锁和信号量实现高效并发控制。生产者线程使用`putq`将整数数据放入队列,消费者线程通过`getq`获取并打印数据。重点展示了队列的创建、操作和同步机制。

#include#include#include#include#include#include#includeclassCThreadQueue

{public:

CThreadQueue(intqueueSize=1024):

sizeQueue(queueSize),lput(0),lget(0)

{

pthread_mutex_init(&mux,0);get=sem_open("get", O_RDWR|O_CREAT);

put=sem_open("put", O_RDWR|O_CREAT);

sem_init(get,0,0);

sem_init(put,0, sizeQueue);

buffer=newvoid*[sizeQueue];

}virtual~CThreadQueue()

{

sem_unlink("get");

sem_unlink("put");

delete[] buffer;

}void*getq()

{

sem_wait(get);void*data;

pthread_mutex_lock(&mux);/*while(lget==lput&&nData==0)

{

nEmptyThread++;

//pthread_cond_wait(&condGet,&mux);

nEmptyThread--;

}*/data=buffer[lget++];//nData--;if(lget==sizeQueue)

{

lget=0;

}/*if(nFullThread) //必要时才进行signal操作,勿总是signal

{

//pthread_cond_signal(&condPut);

sem_post(put);

}*/pthread_mutex_unlock(&mux);

sem_post(put);returndata;

}voidputq(void*data)

{

sem_wait(put);

pthread_mutex_lock(&mux);/*while(lput==lget&&nData)

{

nFullThread++;

//pthread_cond_wait(&condPut,&mux);

sem_wait(put);

nFullThread--;

}*/buffer[lput++]=data;//nData++;if(lput==sizeQueue)

{

lput=0;

}/*if(nEmptyThread)

{

//pthread_cond_signal(&condGet);

sem_post(get);

}*/pthread_mutex_unlock(&mux);

sem_post(get);

}private:

pthread_mutex_t mux;//pthread_cond_t condGet;//pthread_cond_t condPut;sem_t*get;

sem_t*put;void**buffer;//循环消息队列intsizeQueue;//队列大小intlput;//location put  放数据的指针偏移intlget;//location get  取数据的指针偏移};

CThreadQueue queue;//使用的时候给出稍大的CThreadQueue初始化参数,可以减少进入内核态的操作。void*produce(void*arg)

{inti=0;

pthread_detach(pthread_self());while(i++<100)

{

queue.putq((void*)i);

}

}void*consume(void*arg)

{intdata;while(1)

{

data=(int)(queue.getq());

printf("data=%d\n",data);

}

}intmain()

{

pthread_t pid;inti=0;while(i++<3)

pthread_create(&pid,0,produce,0);

i=0;while(i++<3)

pthread_create(&pid,0,consume,0);

sleep(5);return0;

}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值