linux信号量实例,Linux信号量编程实例

本文通过一个C++示例展示了如何使用多线程进行数据入队和出队操作。线程`get_thread`每隔1000毫秒尝试从队列中弹出元素,而线程`put_thread`向队列中插入30个元素。由于队列容量限制为5,当队列满时,入队线程会被阻塞,直到出队线程消费元素。这种机制演示了线程同步和队列满阻塞的基本概念。

//--------------------------test.cpp开始-------------------------------------

//主程序文件

#include "msgdequeue.h" #include

#include

using namespace std;

CMessageDequeue qq(5);

void *get_thread(void *parg);

void *put_thread(void *parg);

void *get_thread(void *parg)

{

while(true)

...{

int a = -1;

if( !qq.pop_front( a,true, 1000 ) ) ...{ cout << "pop failed. size=" << qq.size() << endl;

}

}

return NULL;

}

void *put_thread(void *parg)

{

for(int i=1; i<=30; i++)

...{ qq.push_back( i, -1 );

}

return NULL;

}

int main()

{

pthread_t pget,pput; pthread_create( &pget,NULL,get_thread,NULL);

pthread_create( &pput, NULL, put_thread,NULL);

pthread_join( pget,NULL ); pthread_join( pput,NULL );

return 0;

}

//--------------------------test.cpp结束-------------------------------------............编译程序:g++ msgdequeue.h test.cpp -lpthread -lrt -o test -lpthread链接pthread库。-ltr链接clock_gettime函数相关库。

编译后生成可执行文件test。输入./test执行程序。

线程get_thread每隔1000毫秒从队列取元素,线程put_thread将30个元素依次入队。两个线程模拟两条入队和出队的流水线。因我们在 CMessageDequeue qq(5)处定义了队列最多可容纳5个元素,入队线程每入队到队列元素满5个后需阻塞等待出队线程将队列元素出队才能继续。测试时可调整队列可容纳最大元素个数来观察运行效果。0b1331709591d260c1c78e86d0c51c18.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值