用C++简单实现的——BlockingQueue类(java)

最近,简单整理完Linux线程方面的知识点,突发奇想的想写个线程池来玩玩。经过多方的考虑,决定仿java的线程池来写。由于没有学过java,最后的结果可能差距很大,好像扯远了回到正题来。Java线程池中使用到了BlockingQueue类那就先来试着用C++来实现它吧!

最终只实现了BlockingQueue中的ArrayBlockingQueue(基于数组的阻塞队列实现)和LinkedBlockingQueue(基于链表的阻塞队列)也只实现了BlockingQueue中4个核心的方法。好像对线程池来说够用了。

1.Mutext.h

#ifndef __MUTEX_H__  
#define __MUTEX_H__  
  
#include <pthread.h>  
  
class CMutexLock  
{  
public:  
	explicit CMutexLock()  
	{  
		pthread_mutex_init(&m_Mutex, NULL);  
	}  
  
	~CMutexLock()  
	{  
		pthread_mutex_destroy(&m_Mutex);  
	}  
  
	void lock()  
	{  
		pthread_mutex_lock(&m_Mutex);  
	}  
  
	void unlock()  
	{  
		pthread_mutex_unlock(&m_Mutex);  
	}  
  
	pthread_mutex_t *get()  
	{  
		return &m_Mutex;  
	}  
  
private:  
	friend class CCondition;  
        
	pthread_mutex_t m_Mutex;  
};  
  
    class CMutexLockPart  
    {  
    public:  
        explicit CMutexLockPart(CMutexLock &MutexLock)  
                :m_MutexLock(MutexLock)  
        {  
            m_MutexLock.lock();  
        }  
  
        ~CMutexLockPart()  
        {  
            m_MutexLock.unlock();  
        }  
          
    private:  
        CMutexLock &m_MutexLock;  
    };  
  
#endif  //#ifndef __MUTEX_H__ 
2.Condition.h

#ifndef __CONDITION_H__  
#define __CONDITION_H__  
  
#include "Mutex.h" 

class CCondition  
{  
public:  
	explicit CCondition(CMutexLock &MutexLock)	
		:m_MutexLock(MutexLock)  
	{  
		pthread_cond_init(&m_Condition, NULL);	
	}  

	~CCondition()  
	{  
		pthread_cond_destroy(&m_Condition);  
	}  

	void wait()  
	{  
		pthread_cond_wait(&m_Condition, m_MutexLock.get());  
	}  

	void signal()  
	{  
		pthread_cond_signal(&m_Condition);	
	}  

	void broadcast()  
	{  
		pthread_cond_broadcast(&m_Condition);  
	}  

private:  
	CMutexLock &m_MutexLock;  
	pthread_cond_t m_Cond
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值