IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> Qt 中C++ async实现并行处理 -> 正文阅读

[C++知识库]Qt 中C++ async实现并行处理

在项目中,难免遇到性能问题,为了提高处理的性能,针对可以并行处理的部分单独提取出来,利用并行编程来提高处理的速度,从而实现高性能。C++11中有一个async()函数,非常方便的实现异步处理。
每次调用async()函数,会自动创建一个线程来进行处理,并返回一个future<> 未来变量,根据future变量,可以获取返回值。

async函数解析

函数原型如下:

/// Launch code for futures
 enum class launch
 {
   async = 1,
   deferred = 2
 };
  
template<typename _Fn, typename... _Args>
    using __async_result_of = typename result_of<
      typename decay<_Fn>::type(typename decay<_Args>::type...)>::type;
      
template<typename _Fn, typename... _Args>
    future<__async_result_of<_Fn, _Args...>>
async(launch __policy, _Fn&& __fn, _Args&&... __args);

1、入参

1.1 launch __policy 异步处理的策略,包括两种: async 和 deferred

async = 1,      // 调用async函数的时候就已经运行程序了
deferred = 2    // 延迟运行,当返回的future调用get函数时开始运行异步处理函数。

1.2 _Fn&& __fn 异步处理的函数
1.3 _Args&&… __args 异步处理函数的输入参数。

简单的函数模型为: async(异步策略, 异步处理函数(lamda表达式比较方便), 异步处理函数的参数)

int func(int a) {
	std::cout<<a;
	return a+1;
}

future<int> fu = async(std::launch::async, func, 1000);

2、返回结果

2.1 返回结果为 future 变量,这里的type跟异步处理函数的返回值类型保持一致,例如:

int funcInt(int a) {
	std::cout<<a;
	return a+1;
}

void funcVoid(int a) {
	std::cout<<a;
	return;
}

future<int>  fu = async(std::launch::async, funcInt,  1000);
future<void> fu = async(std::launch::async, funcVoid, 1000);

当policy 设置为deferred 时,返回的future实例调用get函数,此时异步处理才开始例如:

future<int>  fu  = async(std::launch::deferred, funcInt,  1000);
future<void> fu2 = async(std::launch::async,    funcVoid, 1000);  // 此时funcVoid函数开始运行

int ret = fu2.get();   // 运行到这里,funcInt()函数才开始运行
fu.wait();             // 等待funcVoid函数运行完成

async实现异步处理

实例:当前有一个vector向量,长度为10000,处理器是4核,需要将10000个数据拷贝到一个数组中。

void dataCopy(vector<int> &src, int *dst, int dstLen) {
	int len = src.length();
	int threadNum = 4;
	future<void> futureList[threadNum];        // 定义一个future<void> 数组,用来存放async返回值,这里的void是异步函数的返回类型。
	
	for (int i = 0; i < threadNum; i++) {      // for循环对每个线程启动async处理
		futureList[i] = std::async(std::launch::async, [&](int start, int end) {   // policy是async,代表程序运行到这个地方,就已经开始运行后面的lamda表达式了 
			for (int j = start; j < end; j++) {
				dst.at(j) = src.at(j);
			} 
		}, i * len / threadNum, (i + 1) * len / threadNum);  // 后面这两个是lamda表达式的输入参数。
	}
	
	for (int i = 0; i < threadNum; i++) {
		futureList[i].wait();              // 等待所有线程结束
	}
	
	return;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-19 11:52:27  更:2021-08-19 11:54:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 14:44:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码