概述
线程队列头文件 threadqueue.h
#ifndef THREADQUEUE_H_ .#define THREADQUEUE_H_ #include #include using std::cout; using std::endl; const int QUEUESIZE = 20; template class ThreadQueue . { public: ThreadQueue(); ~ThreadQueue(); public: bool Enter(Object *obj); Object* Out(); bool IsEmpty(); bool IsFull(); private: int front; //队列头 int rear; //队列尾. int size; Object *list[QUEUESIZE]; pthread_mutex_t queueMutex; }; //------------------------------------------------------ template ThreadQueue::ThreadQueue() { front = rear = 0; size = QUEUESIZE; pthread_mutex_lock(&queueMutex); } //------------------------------------------------------ template bool ThreadQueue::Enter(Object* obj) { pthread_mutex_lock(&queueMutex); if(IsFull()) { cout << "Queue is full!" << endl; pthread_mutex_unlock(&queueMutex); return false; } //入队 list[rear] = obj; rear = (rear + 1) % size; pthread_mutex_unlock(&queueMutex); return true; } //------------------------------------------------------ 出队列 template Object* ThreadQueue::Out() { Object* temp; pthread_mutex_lock(&queueMutex); if(IsEmpty()) { cout << "Queue is empty!" << endl; pthread_mutex_unlock(&queueMutex); return false; } temp = list[front]; front = (front + 1) % size; pthread_mutex_unlock(&queueMutex); return temp; } //------------------------------------------------------ template bool ThreadQueue::IsEmpty() { if(rear == front) return true; else return false; } //------------------------------------------------------ template bool ThreadQueue::IsFull() { if((rear + 1) % size == front) return true; else return false; } //------------------------------------------------------ template ThreadQueue::~ThreadQueue() { delete []list; } //------------------------------------------------------ #endif /* THREADQUEUE_H_ */
主函数
#include "ThreadQueue.h" #include using namespace std; struct Data { int fd ; //char buf[1024]; }; int main() { ThreadQueue *t = new ThreadQueue(); int k = 10; for(int i = 1; i <= 10; i++) { Data* d = new Data(); d->fd = i; // strcpy(d->buf,"AAAA"); bool a = t->Enter(d); if(a) cout << "true" << endl; else cout << "false" << endl; } Data *temp; //int *temp; for(int i = 1; i <= 10; i++) { //temp = t->Out(); //cout << *temp << endl; temp = t->Out(); cout << temp->fd << endl; //cout << temp->buf << endl; delete temp; } return 0; }
最后
以上就是羞涩墨镜为你收集整理的linux 查看线程队列,基于Linux的多线程安全队列的全部内容,希望文章能够帮你解决linux 查看线程队列,基于Linux的多线程安全队列所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复