实现简单的线程安全Queue

文章目录
  1. 1. 参考资料
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#pragma once

#include <mutex>
#include <queue>

// Thread safe implementation of a Queue using an std::queue
template <typename T>
class SafeQueue {
private:
std::queue<T> m_queue;
std::mutex m_mutex;
public:
SafeQueue() {

}

SafeQueue(SafeQueue& other) {
//TODO:
}

~SafeQueue() {

}


bool empty() {
std::unique_lock<std::mutex> lock(m_mutex);
return m_queue.empty();
}

int size() {
std::unique_lock<std::mutex> lock(m_mutex);
return m_queue.size();
}

void enqueue(T& t) {
std::unique_lock<std::mutex> lock(m_mutex);
m_queue.push(t);
}

bool dequeue(T& t) {
std::unique_lock<std::mutex> lock(m_mutex);

if (m_queue.empty()) {
return false;
}
t = std::move(m_queue.front());

m_queue.pop();
return true;
}
};

参考资料