Files
front_linux/LFtid1056/dealMsg.h

60 lines
1.4 KiB
C
Raw Permalink Normal View History

2025-06-20 09:25:17 +08:00
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <time.h>
#include <queue>
#include <vector>
#include <atomic>
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
#define MESSAGE_QUEUE_SIZE 10000 // <20><>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
/* <20><>Ϣ<EFBFBD><EFBFBD><E1B9B9> */
typedef struct {
int client_index; // <20>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
char* data; // <20><>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD>
size_t length; // <20><>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD>
} deal_message_t;
/* <20>̰߳<DFB3>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD> */
class SafeMessageQueue {
private:
std::queue<deal_message_t> queue;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
std::atomic<int> count{ 0 };
public:
bool push(const deal_message_t& msg) {
pthread_mutex_lock(&mutex);
if (queue.size() >= MESSAGE_QUEUE_SIZE) {
pthread_mutex_unlock(&mutex);
return false;
}
queue.push(msg);
count++;
pthread_cond_signal(&cond);
pthread_mutex_unlock(&mutex);
return true;
}
bool pop(deal_message_t& msg) {
pthread_mutex_lock(&mutex);
while (queue.empty()) {
pthread_cond_wait(&cond, &mutex);
}
msg = queue.front();
queue.pop();
count--;
pthread_mutex_unlock(&mutex);
return true;
}
size_t size() const {
return count.load();
}
};
void process_received_message(int client_index, const char* data, size_t length);