From 18705acc13f78ac65458b3dd832545e62fbc9172 Mon Sep 17 00:00:00 2001
From: wangzhengquan <wangzhengquan85@126.com>
Date: 星期一, 08 二月 2021 10:44:29 +0800
Subject: [PATCH] update

---
 src/queue/lock_free_queue.h |   24 ++++++++++++++----------
 1 files changed, 14 insertions(+), 10 deletions(-)

diff --git a/src/queue/lock_free_queue.h b/src/queue/lock_free_queue.h
index 354c6a4..425d9f8 100644
--- a/src/queue/lock_free_queue.h
+++ b/src/queue/lock_free_queue.h
@@ -13,7 +13,7 @@
 #include "psem.h"
 #include "bus_error.h"
 #include "bus_def.h"
-#include "read_write_lock.h"
+
 // default Queue size
 #define LOCK_FREE_Q_DEFAULT_SIZE 16
 
@@ -83,9 +83,10 @@
   sem_t slots;
   sem_t items;
 
+  time_t createTime;
 
 public:
-  sem_t mutex;
+  // sem_t mutex;
 
 
   LockFreeQueue(size_t qsize = LOCK_FREE_Q_DEFAULT_SIZE);
@@ -95,7 +96,7 @@
   /// template
   ~LockFreeQueue();
 
-  std::atomic_uint reference;
+  // std::atomic_uint reference;
   /// @brief constructor of the class
 
 
@@ -118,6 +119,10 @@
   inline bool empty();
 
   inline ELEM_T &operator[](unsigned i);
+
+  time_t getCreateTime() {
+    return createTime;
+  }
 
   /// @brief push an element at the tail of the queue
   /// @param the element to insert in the queue
@@ -153,15 +158,14 @@
   typename ELEM_T,
   typename Allocator,
   template<typename T, typename AT> class Q_TYPE>
-LockFreeQueue<ELEM_T, Allocator, Q_TYPE>::LockFreeQueue(size_t qsize): reference(0), m_qImpl(qsize) {
+LockFreeQueue<ELEM_T, Allocator, Q_TYPE>::LockFreeQueue(size_t qsize): m_qImpl(qsize) {
   // std::cout << "LockFreeQueue init reference=" << reference << std::endl;
   if (sem_init(&slots, 1, qsize) == -1)
     err_exit(errno, "LockFreeQueue sem_init");
   if (sem_init(&items, 1, 0) == -1)
     err_exit(errno, "LockFreeQueue sem_init");
-  if (sem_init(&mutex, 1, 1) == -1)
-    err_exit(errno, "LockFreeQueue sem_init");
-
+  
+  createTime = time(NULL);
 
 }
 
@@ -178,9 +182,9 @@
   if (sem_destroy(&items) == -1) {
     err_exit(errno, "LockFreeQueue sem_destroy");
   }
-  if (sem_destroy(&mutex) == -1) {
-    err_exit(errno, "LockFreeQueue sem_destroy");
-  }
+  // if (sem_destroy(&mutex) == -1) {
+  //   err_exit(errno, "LockFreeQueue sem_destroy");
+  // }
 }
 
 template<

--
Gitblit v1.8.0