Linux信号量编程实例

本文通过实例展示了Linux环境下如何使用信号量进行多线程同步,具体包括信号量的初始化、等待、释放及销毁等操作。通过创建两个线程,一个负责入队,一个负责出队,演示了在队列满和空时如何利用信号量控制线程的执行。代码编译需要链接pthread和rt库,运行时可以看到线程间的同步效果。

作者:呆若木鸡

    本例示范Linux信号量的基本用法。该范例使用了两个线程分别对一个公用队列进行入队和出队操作,并用信号量进行控制,当队列空时出队操作可以被阻塞,当队列满时入队操作可以被阻塞。

主要用到的信号量函数有:
sem_init:初始化信号量sem_t,初始化的时候可以指定信号量的初始值,以及是否可以在多进程间共享。
sem_wait:一直阻塞等待直到信号量>0。
sem_timedwait:阻塞等待若干时间直到信号量>0。
sem_post:使信号量加1。
sem_destroy:释放信号量。和sem_init对应。
关于各函数的具体参数请用man查看。如man sem_init可查看该函数的帮助。

下面看具体的代码:

// --------------------------msgdequeue.h开始-------------------------------------
// 实现可控队列
#ifndef MSGDEQUEUE_H
#define  MSGDEQUEUE_H
#include 
" tmutex.h "
#include 
< iostream >
#include 
< errno.h >
#include 
< time.h >
#include 
< semaphore.h >
#include 
< deque >
using   namespace  std;

template
< typename T,typename MUTEX_TYPE  =  ThreadMutex >
class  CMessageDequeue
{
public:
        CMessageDequeue(size_t MaxSize) : m_MaxSize( MaxSize )
        
{
                sem_init( 
&m_enques,0, m_MaxSize ); //入队信号量初始化为MaxSize,最多可容纳MaxSize各元素
                sem_init( &m_deques,0,0 ); //队列刚开始为空,出队信号量初始为0
        }


        
~CMessageDequeue()
        
{
                sem_destroy(
&m_enques);
                sem_destroy(
&m_deques);
        }


        
int sem_wait_i( sem_t *psem, int mswait )
        
{ //等待信号量变成>0,mswait为等待时间,若mswait<0则无穷等待,否则等待若干mswait毫秒。
                if( mswait < 0 )
                
{
                        
int rv = 0;                          
                        
while( ((rv = sem_wait(psem) ) != 0 ) && (errno == EINTR
) );    
//等待信号量,errno==EINTR屏蔽其他信号事件引起的等待中断
                        return rv;    
                }
                                            
                
else                           &nb
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值