简单的UDP多线程模型

和Lite2D项目中的网络线程和主线程 交互方式 差不多

在这里,队列是线程安全的,


#include <iostream>
#include <list>
#include <string>
#include <algorithm>
#include <vector>
#include <thread>
#include <fstream>
#include <stdlib.h>
#include <stdio.h>
#include "windows.h"
#include <functional>
#include "direct.h"
#include <map>
#include <memory>
#include <queue>
#include <condition_variable>
#include <mutex>

using namespace std;

#define  LOCK(WHAT)   std::unique_lock<std::mutex> locker(WHAT);

template<class T>
class QueueThreadSafe
{
public:
	void push(T &t)
	{
		LOCK(this->_mutex);
		this->_queue.push(t);
	}
	T front()
	{
		LOCK(this->_mutex);
		T & ret = this->_queue.front();
		this->_queue.pop();
		return ret;
	}

	bool empty()
	{
		LOCK(this->_mutex);
		bool ret = this->_queue.empty();
		return ret;
	}
private:
	std::queue<T>  _queue;
	std::mutex _mutex;

};


class UDPClient
{
public:
	void send(char *buffer)
	{

		LOCK(this->_mutex);

		reqs.push(buffer);

		this->_cond.notify_all();
	}
	void loop()
	{
		while (this->isRun)
		{
			LOCK(this->_mutex);

			if (this->reqs.empty() == true)
			{//如果队列为空,那么等待唤醒
				this->_cond.wait(this->_mutex);
			}

			cout << "send :" << reqs.front() << endl;
		}
	}

	bool isRun = true;
	std::mutex _mutex;
	QueueThreadSafe<char*> reqs;
	std::condition_variable_any _cond;
};


static  UDPClient* instance;

static void workThreadFunc()
{
	instance = new UDPClient;
	instance->loop();
}


int main()
{

	std::thread t(workThreadFunc);

	t.detach();


	char str[100];
	int index = 0;

	while (true)
	{
		//	Sleep(1);
		sprintf(str, "%d", index++);
		instance->send(str);
	}

	system("pause");

	return 0;
}

 

 

转载于:https://my.oschina.net/kkkkkkkkkkkkk/blog/737378

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值