⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 constantsizedfifo.h

📁 Larbin互联网蜘蛛索引系统
💻 H
字号:
// Larbin// Sebastien Ailleret// 15-04-00 -> 15-04-00/* this fifo will not grow */#ifndef CONSTANTFIFO_H#define CONSTANTFIFO_H#include <assert.h>#include <pthread.h>#include "xutils/GenericFifo.h"template <class T>class ConstantSizedFifo : public GenericFifo<T> { protected:  uint size;  T **tab;  pthread_mutex_t lock;  pthread_cond_t nonEmpty; public:  /* Specific constructor */  ConstantSizedFifo (uint size);  /* Destructor */  virtual ~ConstantSizedFifo ();  /* get the first object */  virtual T *get ();  /* get the first object (non totally blocking)   * return NULL if there is none   */  virtual T *tryGet ();  /* add an object in the fifo */  virtual void put (T *obj);  /* add an object in the fifo   * never block !!!   */  virtual void putForce (T *obj);  /* how many itmes are there inside ? */  virtual int getLength ();};template <class T>ConstantSizedFifo<T>::ConstantSizedFifo (uint size) {  this->size = size+1;  tab = new T*[this->size];  in = 0;  out = 0;  pthread_mutex_init (&lock, NULL);  pthread_cond_init (&nonEmpty, NULL);}template <class T>ConstantSizedFifo<T>::~ConstantSizedFifo () {  delete [] tab;  pthread_mutex_destroy (&lock);  pthread_cond_destroy (&nonEmpty);}template <class T>T *ConstantSizedFifo<T>::get () {  T *tmp;  pthread_mutex_lock(&lock);  while (in == out) {    pthread_cond_wait(&nonEmpty, &lock);  }  tmp = tab[out];  out = (out + 1) % size;  pthread_mutex_unlock(&lock);  return tmp;}template <class T>T *ConstantSizedFifo<T>::tryGet () {  T *tmp = NULL;  pthread_mutex_lock(&lock);  if (in != out) {	// The stack is not empty	tmp = tab[out];	out = (out + 1) % size;  }  pthread_mutex_unlock(&lock);  return tmp;}template <class T>void ConstantSizedFifo<T>::put (T *obj) {  pthread_mutex_lock(&lock);  tab[in] = obj;  if (in == out) {    pthread_cond_broadcast(&nonEmpty);  }  in = (in + 1) % size;  assert (in != out);  pthread_mutex_unlock(&lock);}template <class T>void ConstantSizedFifo<T>::putForce (T *obj) {  pthread_mutex_lock(&lock);  tab[in] = obj;  if (in == out) {    pthread_cond_broadcast(&nonEmpty);  }  in = (in + 1) % size;  assert(in != out);  pthread_mutex_unlock(&lock);}template <class T>int ConstantSizedFifo<T>::getLength () {  int tmp;  pthread_mutex_lock(&lock);  tmp = (in + size - out) % size;  pthread_mutex_unlock(&lock);  return tmp;}#endif // CONSTANTFIFO_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -