C++并发与多线程-线程之间传递任务

本文介绍了在C++中如何利用std::packaged_task实现线程间的任务传递。通过封装可调用对象,并将其放入公共容器,任务执行线程持有future对象,当需要数据时,调用future的get()或wait()方法进行阻塞等待。执行完成后,future变为可获取状态,避免阻塞,保证GUI线程的正常运行。
摘要由CSDN通过智能技术生成

       线程之间传递回调函数或者任务的一种方法是使用std::packaged_task封装可调用对象,然后将std::packaged_task对象放入公共容器里面,然后被调用任务的线程持到std::packaged_task里面的future对象,当需要数据的时候调用future对象的get()或wait()方法即可阻塞并等待。执行任务的线程执行完可调用对象之后,该future就变为可获得的状态。被调用任务的线程就不再阻塞,继续执行。下面程序模拟了GUI收到更新消息并执行回调任务的例子。

//GUIThreadWorker.h

#pragma once
#include<queue>
#include<future>
#include<thread>
class GUIThreadWorker {
private:
	GUIThreadWorker();
	~GUIThreadWorker();
	std::deque<std::packaged_task<void()> > tasks;
	std::mutex lock;
	bool done = false;
	std::thread gui_thread;
private:
	void start();
public:
	GUIThreadWorker(const GUIThreadWorker& other) = delete;
	GUIThreadWorker& operator=(const GUIThreadWorker& other) = delete;
	static GUIThreadWorker* getInstance();
	static GUIThreadWorker* instance;
	static std::mutex mtx;
	static std::once_flag s_flag;

	template<typename Func> std::future<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值