From 8ec1d776751f62c43335d36c3427dc1ab2d84a61 Mon Sep 17 00:00:00 2001
From: wangzhengquan <wangzhengquan85@126.com>
Date: 星期六, 25 七月 2020 13:52:06 +0800
Subject: [PATCH] commit

---
 src/queue/include/shm_queue.h |   14 ++++++++++----
 1 files changed, 10 insertions(+), 4 deletions(-)

diff --git a/src/queue/include/shm_queue.h b/src/queue/include/shm_queue.h
index 394545b..26bf019 100644
--- a/src/queue/include/shm_queue.h
+++ b/src/queue/include/shm_queue.h
@@ -2,12 +2,11 @@
 #define __SHM_QUEUE_H__
 
 #include "usg_common.h"
-#include "mm.h"
 #include "hashtable.h"
 #include "lock_free_queue.h"
 #include "logger_factory.h"
 #include "shm_allocator.h"
-
+#include "sem_util.h"
 // default Queue size
 // #define LOCK_FREE_Q_DEFAULT_SIZE 16
  
@@ -98,14 +97,18 @@
 template < typename ELEM_T >
 SHMQueue<ELEM_T>::~SHMQueue()
 {
+    SemUtil::dec( queue->mutex);
     queue->reference--;
     LoggerFactory::getLogger().debug("SHMQueue destructor  reference===%d", queue->reference.load());
     if(queue->reference.load() == 0) {
         delete queue;
         hashtable_t *hashtable = mm_get_hashtable();
         hashtable_remove(hashtable, KEY);
-        LoggerFactory::getLogger().debug("SHMQueue destructor delete queue");
+printf("SHMQueue destructor delete queue\n");
+    } else {
+        SemUtil::inc(queue->mutex);
     }
+    
 }
 
 template < typename ELEM_T >
@@ -156,7 +159,10 @@
 template < typename ELEM_T >
 inline bool SHMQueue<ELEM_T>::pop(ELEM_T &a_data)
 {
-   return queue->pop(a_data);
+// printf("SHMQueue pop before\n");
+   int rv = queue->pop(a_data);
+// printf("SHMQueue after before\n");
+   return rv;
     
 }
 

--
Gitblit v1.8.0