登录社区云,与社区用户共同成长
邀请您加入社区
<br />线程队列头文件 threadqueue.h<br />#ifndef THREADQUEUE_H_.#define THREADQUEUE_H_#include <pthread.h>#include <iostream>using std::cout;using std::endl;const int QUEUESIZE = 20;template<class Object>cla
线程队列头文件 threadqueue.h
#ifndef THREADQUEUE_H_ .#define THREADQUEUE_H_ #include <pthread.h> #include <iostream> using std::cout; using std::endl; const int QUEUESIZE = 20; template<class Object> 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<class Object> ThreadQueue<Object>::ThreadQueue() { front = rear = 0; size = QUEUESIZE; pthread_mutex_lock(&queueMutex); } //------------------------------------------------------ template<class Object> bool ThreadQueue<Object>::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<class Object> Object* ThreadQueue<Object>::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<class Object> bool ThreadQueue<Object>::IsEmpty() { if(rear == front) return true; else return false; } //------------------------------------------------------ template<class Object> bool ThreadQueue<Object>::IsFull() { if((rear + 1) % size == front) return true; else return false; } //------------------------------------------------------ template<class Object> ThreadQueue<Object>::~ThreadQueue() { delete []list; } //------------------------------------------------------ #endif /* THREADQUEUE_H_ */
主函数
#include "ThreadQueue.h" #include <iostream> using namespace std; struct Data { int fd ; //char buf[1024]; }; int main() { ThreadQueue<Data> *t = new ThreadQueue<Data>(); 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; }
更多推荐
网卡速率和双工模式的配置
http://linux.chinaitlab.com/system/792187.html1、mii-tool 配置网络设备协商方式的工具; 1.1 mii-tool 介绍; mii-tool - view, manipulate media-independent interface status (mii-tool 是查看,管理介质的网络接口的状态)
Linux虚拟文件系统之文件系统卸载(sys_umount())
Linux中卸载文件系统由umount系统调用实现,入口函数为sys_umount()。较于文件系统的安装较为简单,下面是具体的实现。1. /*sys_umont系统调用*/2. SYSCALL_DEFINE2(umount, char __user *, name, int, flags)3. {4.struct path path;
Linux系统下超级终端Minicom的使用方法(例如:连接交换机,路由器等)转http://baike.baidu.com/view/2911642.htm?fr=ala0_1
<br /> Linux系统下超级终端Minicom的使用方法 <br /> Linux下的Minicom的功能与下的超级终端功能相似,适于在通过超级终端对设备的管理以及对嵌入操作系统的升级,现写出Minicom的使用手册: <br /> 1. 启动minicom <br /> 以root权限登录系统 <br /> 使用命令 <br /> minicom –s 则minicom启动,屏
扫一扫分享内容
所有评论(0)