线程同步机制的封装

  •  syn_pthread.h
#ifndef _SYN_PTHREAD_H_
#define _SYN_PTHREAD_H_

#include <exception>
#include <pthread.h>
#include <semaphore.h>

/*封装信号量*/
class sem{
public:
	sem()//创建并初始化信号量
	{
		if(sem_init(&m_sem,0,0)!=0)
		{
			throw std::exception();//初始化函数没有返回值抛出异常
		}
	}
	~sem()//销毁信号量
	{
		sem_destroy(&m_sem);
	}
	bool wait()//等待信号量
	{
		return sem_wait(&m_sem)==0;
	}
	bool post()//增加信号量
	{
		return sem_post(&m_sem)==0;
	}
private:
	sem_t m_sem;
};

/*封装互斥锁*/
class locker
{
public:
	locker()//创建并初始化互斥锁
	{
		if(pthread_mutex_init(&m_mutex,NULL)!=0)
		{
			throw std::exception();
		}
	~locker()//销毁互斥锁
	{
		pthread_mutex_destroy(&m_mutex);
	}
	bool lock()//获取互斥锁
	{
		return pthread_mutex_lock(&m_mutex)==0;
	}
	bool unlock()//释放互斥锁
	{
		return pthread_mutex_unlock(&m_mutex)==0;
	}
private:
	pthread_mutex_t m_mutex;
};

/*封装条件变量*/
class cond{
public:
	cond()//创建并初始化条件变量
	{
		if(pthread_mutex_init(&m_mutex,NULL!=0)
			throw std::exception();
		if(pthread_cond_init(&m_cond,NULL)!=0)
		{
			//构造函数出问题就立即释放已经成功分配的资源
			pthread_mutex_destroy(&m_mutex);
			throw std::exception();
		}
	}
	~cond()//销毁条件变量
	{
		pthread_mutex_destroy(&m_mutex);
		pthread_cond_destroy(&m_cond);
	}
	bool wait()//等待条件变量
	{
		int ret=0;
		pthread_mutex_lock(&m_mutex);
		ret=pthread_cond_wait(&m_cond,&m_mutex);
		pthread_mutex_unlock(&m_mutex);
		return  ret==0;
	}
	bool signal()//唤醒等待条件变量的线程
	{
		return pthread_cond_signal(&m_cond)==0;
	}
private:
	pthread_mutex_t m_mutex;
	pthread_cond_t m_cond;
};

#endif

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值